Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Integer / testalloca_bt.ll
blobe8e73c50878d2b9d80d366d271a6a83113f65b3e
1 ; RUN: llvm-as %s -o - | llvm-dis > %t1.ll
2 ; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
3 ; RUN: diff %t1.ll %t2.ll
6 %inners = type {float, {i8 } }
7 %struct = type { i33 , {float, {i8 } } , i64 }
10 define i33 @testfunction(i33 %i0, i33 %j0)
11 begin
12     alloca i8, i32 5
13     %ptr = alloca i33                       ; yields {i33*}:ptr
14     store i33 3, i33* %ptr                  ; yields {void}
15     %val = load i33* %ptr                   ; yields {i33}:val = i33 %3
17     %sptr = alloca %struct                  ; yields {%struct*}:sptr
18     %nsptr = getelementptr %struct * %sptr, i64 0, i32 1  ; yields {inners*}:nsptr
19     %ubsptr = getelementptr %inners * %nsptr, i64 0, i32 1  ; yields {{i8}*}:ubsptr
20     %idx = getelementptr {i8} * %ubsptr, i64 0, i32 0
21     store i8 4, i8* %idx
22     
23     %fptr = getelementptr %struct * %sptr, i64 0, i32 1, i32 0  ; yields {float*}:fptr
24     store float 4.0, float * %fptr
25     
26     ret i33 3
27 end