Home | History | Annotate | Download | only in Thumb2
      1 ; RUN: llc < %s -march=thumb -mattr=+thumb2 | FileCheck %s
      2 
      3 define i32 @f1(i32 %a.s) {
      4 entry:
      5 ; CHECK: f1:
      6 ; CHECK: it eq
      7 ; CHECK: moveq
      8 
      9     %tmp = icmp eq i32 %a.s, 4
     10     %tmp1.s = select i1 %tmp, i32 2, i32 3
     11     ret i32 %tmp1.s
     12 }
     13 
     14 define i32 @f2(i32 %a.s) {
     15 entry:
     16 ; CHECK: f2:
     17 ; CHECK: it gt
     18 ; CHECK: movgt
     19     %tmp = icmp sgt i32 %a.s, 4
     20     %tmp1.s = select i1 %tmp, i32 2, i32 3
     21     ret i32 %tmp1.s
     22 }
     23 
     24 define i32 @f3(i32 %a.s, i32 %b.s) {
     25 entry:
     26 ; CHECK: f3:
     27 ; CHECK: it lt
     28 ; CHECK: movlt
     29     %tmp = icmp slt i32 %a.s, %b.s
     30     %tmp1.s = select i1 %tmp, i32 2, i32 3
     31     ret i32 %tmp1.s
     32 }
     33 
     34 define i32 @f4(i32 %a.s, i32 %b.s) {
     35 entry:
     36 ; CHECK: f4:
     37 ; CHECK: it le
     38 ; CHECK: movle
     39 
     40     %tmp = icmp sle i32 %a.s, %b.s
     41     %tmp1.s = select i1 %tmp, i32 2, i32 3
     42     ret i32 %tmp1.s
     43 }
     44 
     45 define i32 @f5(i32 %a.u, i32 %b.u) {
     46 entry:
     47 ; CHECK: f5:
     48 ; CHECK: it ls
     49 ; CHECK: movls
     50     %tmp = icmp ule i32 %a.u, %b.u
     51     %tmp1.s = select i1 %tmp, i32 2, i32 3
     52     ret i32 %tmp1.s
     53 }
     54 
     55 define i32 @f6(i32 %a.u, i32 %b.u) {
     56 entry:
     57 ; CHECK: f6:
     58 ; CHECK: it hi
     59 ; CHECK: movhi
     60     %tmp = icmp ugt i32 %a.u, %b.u
     61     %tmp1.s = select i1 %tmp, i32 2, i32 3
     62     ret i32 %tmp1.s
     63 }
     64 
     65 define i32 @f7(i32 %a, i32 %b, i32 %c) {
     66 entry:
     67 ; CHECK: f7:
     68 ; CHECK: it hi
     69 ; CHECK: lsrhi.w
     70     %tmp1 = icmp ugt i32 %a, %b
     71     %tmp2 = udiv i32 %c, 3
     72     %tmp3 = select i1 %tmp1, i32 %tmp2, i32 3
     73     ret i32 %tmp3
     74 }
     75 
     76 define i32 @f8(i32 %a, i32 %b, i32 %c) {
     77 entry:
     78 ; CHECK: f8:
     79 ; CHECK: it lo
     80 ; CHECK: lsllo.w
     81     %tmp1 = icmp ult i32 %a, %b
     82     %tmp2 = mul i32 %c, 4
     83     %tmp3 = select i1 %tmp1, i32 %tmp2, i32 3
     84     ret i32 %tmp3
     85 }
     86 
     87 define i32 @f9(i32 %a, i32 %b, i32 %c) {
     88 entry:
     89 ; CHECK: f9:
     90 ; CHECK: it ge
     91 ; CHECK: rorge.w
     92     %tmp1 = icmp sge i32 %a, %b
     93     %tmp2 = shl i32 %c, 10
     94     %tmp3 = lshr i32 %c, 22
     95     %tmp4 = or i32 %tmp2, %tmp3
     96     %tmp5 = select i1 %tmp1, i32 %tmp4, i32 3
     97     ret i32 %tmp5
     98 }
     99