In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / Transforms / SimplifyCFG / 2006-10-19-UncondDiv.ll
blob0d056eed74e1010e90d5a9fa94d31d4f7b5fb2f6
1 ; PR957
2 ; RUN: llvm-as < %s | opt -simplifycfg | llvm-dis | \
3 ; RUN:   not grep select
5 @G = extern_weak global i32
7 define i32 @test(i32 %tmp) {
8 cond_false179:
9         %tmp181 = icmp eq i32 %tmp, 0           ; <i1> [#uses=1]
10         br i1 %tmp181, label %cond_true182, label %cond_next185
11 cond_true182:           ; preds = %cond_false179
12         br label %cond_next185
13 cond_next185:           ; preds = %cond_true182, %cond_false179
14         %d0.3 = phi i32 [ udiv (i32 1, i32 ptrtoint (i32* @G to i32)), %cond_true182 ], [ %tmp, %cond_false179 ]                ; <i32> [#uses=1]
15         ret i32 %d0.3
18 define i32 @test2(i32 %tmp) {
19 cond_false179:
20         %tmp181 = icmp eq i32 %tmp, 0           ; <i1> [#uses=1]
21         br i1 %tmp181, label %cond_true182, label %cond_next185
22 cond_true182:           ; preds = %cond_false179
23         br label %cond_next185
24 cond_next185:           ; preds = %cond_true182, %cond_false179
25         %d0.3 = phi i32 [ udiv (i32 1, i32 ptrtoint (i32* @G to i32)), %cond_true182 ], [ %tmp, %cond_false179 ]                ; <i32> [#uses=1]
26         call i32 @test( i32 4 )         ; <i32>:0 [#uses=0]
27         ret i32 %d0.3