In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / Transforms / JumpThreading / and-cond.ll
blobb01c4baffc0ed8e3ab9f02a7e4119b6c61032041
1 ; RUN: llvm-as < %s | opt -jump-threading -mem2reg -instcombine -simplifycfg  | llvm-dis | grep {ret i32 %v1}
2 ; There should be no uncond branches left.
3 ; RUN: llvm-as < %s | opt -jump-threading -mem2reg -instcombine -simplifycfg  | llvm-dis | not grep {br label}
5 declare i32 @f1()
6 declare i32 @f2()
7 declare void @f3()
9 define i32 @test(i1 %cond, i1 %cond2) {
10         br i1 %cond, label %T1, label %F1
12 T1:
13         %v1 = call i32 @f1()
14         br label %Merge
16 F1:
17         %v2 = call i32 @f2()
18         br label %Merge
20 Merge:
21         %A = phi i1 [true, %T1], [false, %F1]
22         %B = phi i32 [%v1, %T1], [%v2, %F1]
23         %C = and i1 %A, %cond2
24         br i1 %C, label %T2, label %F2
26 T2:
27         call void @f3()
28         ret i32 %B
30 F2:
31         ret i32 %B