Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / CodeGen / Generic / pr2625.ll
blob3e3dc4b2d2bcf8219d912e42dd1dc736fa6ccf70
1 ; RUN: llc < %s
2 ; PR2625
4 define i32 @main({ i32, { i32 } }*) {
5 entry:
6         %state = alloca { i32, { i32 } }*               ; <{ i32, { i32 } }**> [#uses=2]
7         store { i32, { i32 } }* %0, { i32, { i32 } }** %state
8         %retval = alloca i32            ; <i32*> [#uses=2]
9         store i32 0, i32* %retval
10         load { i32, { i32 } }** %state          ; <{ i32, { i32 } }*>:1 [#uses=1]
11         store { i32, { i32 } } zeroinitializer, { i32, { i32 } }* %1
12         br label %return
14 return:         ; preds = %entry
15         load i32* %retval               ; <i32>:2 [#uses=1]
16         ret i32 %2