Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Analysis / ScalarEvolution / 2008-12-08-FiniteSGE.ll
blob2ee107a4a43a93e570dabfb6058bc3e15875dd95
1 ; RUN: opt < %s -analyze -scalar-evolution -disable-output | grep {backedge-taken count is 255}
2 ; XFAIL: *
4 define i32 @foo(i32 %x, i32 %y, i32* %lam, i32* %alp) nounwind {
5 bb1.thread:
6         br label %bb1
8 bb1:            ; preds = %bb1, %bb1.thread
9         %indvar = phi i32 [ 0, %bb1.thread ], [ %indvar.next, %bb1 ]            ; <i32> [#uses=4]
10         %i.0.reg2mem.0 = sub i32 255, %indvar           ; <i32> [#uses=2]
11         %0 = getelementptr i32* %alp, i32 %i.0.reg2mem.0                ; <i32*> [#uses=1]
12         %1 = load i32* %0, align 4              ; <i32> [#uses=1]
13         %2 = getelementptr i32* %lam, i32 %i.0.reg2mem.0                ; <i32*> [#uses=1]
14         store i32 %1, i32* %2, align 4
15         %3 = sub i32 254, %indvar               ; <i32> [#uses=1]
16         %4 = icmp slt i32 %3, 0         ; <i1> [#uses=1]
17         %indvar.next = add i32 %indvar, 1               ; <i32> [#uses=1]
18         br i1 %4, label %bb2, label %bb1
20 bb2:            ; preds = %bb1
21         %tmp10 = mul i32 %indvar, %x            ; <i32> [#uses=1]
22         %z.0.reg2mem.0 = add i32 %tmp10, %y             ; <i32> [#uses=1]
23         %5 = add i32 %z.0.reg2mem.0, %x         ; <i32> [#uses=1]
24         ret i32 %5