Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Transforms / InstCombine / setcc-cast-cast.ll
blobb2681ea29863377b1b4d8b73e26b68685ee83457
1 ; This test case was reduced from MultiSource/Applications/hbd. It makes sure
2 ; that folding doesn't happen in case a zext is applied where a sext should have
3 ; been when a setcc is used with two casts.
4 ; RUN: opt < %s -instcombine -S | \
5 ; RUN:    not grep {br i1 false}
6 ; END.
8 define i32 @bug(i8 %inbuff) {
9 entry:
10         %tmp = bitcast i8 %inbuff to i8         ; <i8> [#uses=1]
11         %tmp.upgrd.1 = sext i8 %tmp to i32              ; <i32> [#uses=3]
12         %tmp.upgrd.2 = icmp eq i32 %tmp.upgrd.1, 1              ; <i1> [#uses=1]
13         br i1 %tmp.upgrd.2, label %cond_true, label %cond_next
15 cond_true:              ; preds = %entry
16         br label %bb
18 cond_next:              ; preds = %entry
19         %tmp3 = icmp eq i32 %tmp.upgrd.1, -1            ; <i1> [#uses=1]
20         br i1 %tmp3, label %cond_true4, label %cond_next5
22 cond_true4:             ; preds = %cond_next
23         br label %bb
25 cond_next5:             ; preds = %cond_next
26         %tmp7 = icmp sgt i32 %tmp.upgrd.1, 1            ; <i1> [#uses=1]
27         br i1 %tmp7, label %cond_true8, label %cond_false
29 cond_true8:             ; preds = %cond_next5
30         br label %cond_next9
32 cond_false:             ; preds = %cond_next5
33         br label %cond_next9
35 cond_next9:             ; preds = %cond_false, %cond_true8
36         %iftmp.1.0 = phi i32 [ 42, %cond_true8 ], [ 23, %cond_false ]           ; <i32> [#uses=1]
37         br label %return
39 bb:             ; preds = %cond_true4, %cond_true
40         br label %return
42 return:         ; preds = %bb, %cond_next9
43         %retval.0 = phi i32 [ 17, %bb ], [ %iftmp.1.0, %cond_next9 ]            ; <i32> [#uses=1]
44         ret i32 %retval.0