Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Analysis / ScalarEvolution / 2007-08-06-Unsigned.ll
blobf623da1b2757563f4b455f0cb294e22251198584
1 ; RUN: opt < %s -scalar-evolution -analyze -disable-output | grep {Loop bb: backedge-taken count is (-1 + (-1 \\* %x) + %y)}
2 ; PR1597
4 define i32 @f(i32 %x, i32 %y) {
5 entry:
6         %tmp63 = icmp ult i32 %x, %y            ; <i1> [#uses=1]
7         br i1 %tmp63, label %bb.preheader, label %bb8
9 bb.preheader:           ; preds = %entry
10         br label %bb
12 bb:             ; preds = %bb3, %bb.preheader
13         %x_addr.0 = phi i32 [ %tmp2, %bb3 ], [ %x, %bb.preheader ]              ; <i32> [#uses=1]
14         %tmp2 = add i32 %x_addr.0, 1            ; <i32> [#uses=3]
15         br label %bb3
17 bb3:            ; preds = %bb
18         %tmp6 = icmp ult i32 %tmp2, %y          ; <i1> [#uses=1]
19         br i1 %tmp6, label %bb, label %bb8.loopexit
21 bb8.loopexit:           ; preds = %bb3
22         br label %bb8
24 bb8:            ; preds = %bb8.loopexit, %entry
25         %x_addr.1 = phi i32 [ %x, %entry ], [ %tmp2, %bb8.loopexit ]            ; <i32> [#uses=1]
26         br label %return
28 return:         ; preds = %bb8
29         ret i32 %x_addr.1