Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Transforms / InstCombine / extractvalue.ll
blob875f860b3d7fa416f5dd8dc5f3fd09e3e434411d
1 ; RUN: opt < %s -instcombine -S | not grep extractvalue
3 ; Instcombine should fold various combinations of insertvalue and extractvalue
4 ; together
5 declare void @bar({i32, i32} %a)
7 define i32 @foo() {
8         ; Build a simple struct and pull values out again
9         %s1.1 = insertvalue {i32, i32} undef, i32 0, 0
10         %s1 = insertvalue {i32, i32} %s1.1, i32 1, 1
11         %v1 = extractvalue {i32, i32} %s1, 0
12         %v2 = extractvalue {i32, i32} %s1, 1
13         
14         ; Build a nested struct and pull a sub struct out of it
15         ; This requires instcombine to insert a few insertvalue instructions
16         %ns1.1 = insertvalue {i32, {i32, i32}} undef, i32 %v1, 0
17         %ns1.2 = insertvalue {i32, {i32, i32}} %ns1.1, i32 %v1, 1, 0
18         %ns1   = insertvalue {i32, {i32, i32}} %ns1.2, i32 %v2, 1, 1
19         %s2    = extractvalue {i32, {i32, i32}} %ns1, 1
20         %v3    = extractvalue {i32, {i32, i32}} %ns1, 1, 1
21         call void @bar({i32, i32} %s2)
23         ; Use nested extractvalues to get to a value
24         %s3    = extractvalue {i32, {i32, i32}} %ns1, 1
25         %v4    = extractvalue {i32, i32} %s3, 1
26         call void @bar({i32, i32} %s3)
28         ; Use nested insertvalues to build a nested struct
29         %s4.1 = insertvalue {i32, i32} undef, i32 %v3, 0
30         %s4   = insertvalue {i32, i32} %s4.1, i32 %v4, 1
31         %ns2  = insertvalue {i32, {i32, i32}} undef, {i32, i32} %s4, 1
33         ; And now extract a single value from there
34         %v5   = extractvalue {i32, {i32, i32}} %ns2, 1, 1
36         ret i32 %v5