Checkpoint Thumb2 Instr info work. Generalized base code so that it can be shared...
[oota-llvm.git] / test / CodeGen / Thumb2 / thumb2-select_xform.ll
1 ; XFAIL: *
2 ; fixme
3 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | grep mov | count 3
4 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | grep mvn | count 1
5
6 define i32 @t1(i32 %a, i32 %b, i32 %c) nounwind {
7         %tmp1 = icmp sgt i32 %c, 10
8         %tmp2 = select i1 %tmp1, i32 0, i32 2147483647
9         %tmp3 = add i32 %tmp2, %b
10         ret i32 %tmp3
11 }
12
13 define i32 @t2(i32 %a, i32 %b, i32 %c) nounwind {
14         %tmp1 = icmp sgt i32 %c, 10
15         %tmp2 = select i1 %tmp1, i32 0, i32 2147483648
16         %tmp3 = add i32 %tmp2, %b
17         ret i32 %tmp3
18 }
19
20 define i32 @t3(i32 %a, i32 %b, i32 %c, i32 %d) nounwind {
21         %tmp1 = icmp sgt i32 %c, 10
22         %tmp2 = select i1 %tmp1, i32 0, i32 10
23         %tmp3 = sub i32 %b, %tmp2
24         ret i32 %tmp3
25 }