Use MachineBasicBlock::transferSuccessors.
[oota-llvm.git] / test / Transforms / InstCombine / bswap-fold.ll
1 ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep ret | count 6
2 ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep call.*bswap
3
4 define i1 @test1(i16 %tmp2) {
5         %tmp10 = call i16 @llvm.bswap.i16( i16 %tmp2 )          ; <i16> [#uses=1]
6         %tmp = icmp eq i16 %tmp10, 1            ; <i1> [#uses=1]
7         ret i1 %tmp
8 }
9
10 define i1 @test2(i32 %tmp) {
11         %tmp34 = tail call i32 @llvm.bswap.i32( i32 %tmp )              ; <i32> [#uses=1]
12         %tmp.upgrd.1 = icmp eq i32 %tmp34, 1            ; <i1> [#uses=1]
13         ret i1 %tmp.upgrd.1
14 }
15
16 declare i32 @llvm.bswap.i32(i32)
17
18 define i1 @test3(i64 %tmp) {
19         %tmp34 = tail call i64 @llvm.bswap.i64( i64 %tmp )              ; <i64> [#uses=1]
20         %tmp.upgrd.2 = icmp eq i64 %tmp34, 1            ; <i1> [#uses=1]
21         ret i1 %tmp.upgrd.2
22 }
23
24 declare i64 @llvm.bswap.i64(i64)
25
26 declare i16 @llvm.bswap.i16(i16)
27
28 ; rdar://5992453
29 ; A & 255
30 define i32 @test4(i32 %a) nounwind  {
31 entry:
32         %tmp2 = tail call i32 @llvm.bswap.i32( i32 %a ) 
33         %tmp4 = lshr i32 %tmp2, 24
34         ret i32 %tmp4
35 }
36
37 ; A
38 define i32 @test5(i32 %a) nounwind  {
39 entry:
40         %tmp2 = tail call i32 @llvm.bswap.i32( i32 %a )
41         %tmp4 = tail call i32 @llvm.bswap.i32( i32 %tmp2 )
42         ret i32 %tmp4
43 }
44
45 ; a >> 24
46 define i32 @test6(i32 %a) nounwind  {
47 entry:
48         %tmp2 = tail call i32 @llvm.bswap.i32( i32 %a ) 
49         %tmp4 = and i32 %tmp2, 255
50         ret i32 %tmp4
51 }
52