opt-addr-mode-subreg-use.ll
6.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
; RUN: llc -march=hexagon < %s
; REQUIRES: asserts
target triple = "hexagon"
%s.0 = type { i32*, i32*, i32* }
%s.1 = type { i32*, i32*, i32* }
%s.2 = type { i32*, i32**, i32**, i32**, i32***, i32* }
%s.3 = type { i32*, i32*, i32* }
%s.4 = type { i32*, i32*, i32* }
%s.5 = type { i32*, i32*, i32 }
; Function Attrs: nounwind optsize
declare zeroext i1 @f0(i32*) #0 align 2
; Function Attrs: nounwind optsize
declare zeroext i1 @f1(i32*) #0 align 2
; Function Attrs: optsize
declare hidden void @f2(i32* noalias nocapture sret, i32) #1 align 2
; Function Attrs: optsize
declare hidden void @f3(i32* noalias nocapture sret, i32) #1 align 2
; Function Attrs: optsize
declare hidden void @f4(i32* noalias nocapture sret, i32) #1 align 2
; Function Attrs: optsize
declare hidden void @f5(i32* noalias nocapture sret, i32) #1 align 2
; Function Attrs: optsize
declare hidden void @f6(i32* noalias nocapture sret, i32) #1 align 2
; Function Attrs: optsize
declare hidden void @f7(i32* noalias nocapture sret, i32) #1 align 2
; Function Attrs: optsize
declare zeroext i1 @f8(i32*, i32*, i64) #1 align 2
; Function Attrs: nounwind optsize
declare i32* @f9(i32* nocapture readonly) #0 align 2
; Function Attrs: optsize
define void @f10(i32* %a0, i32* dereferenceable(64) %a1) #1 align 2 {
b0:
%v0 = alloca %s.0, align 4
%v1 = alloca %s.1, align 4
%v2 = alloca %s.2, align 4
%v3 = alloca %s.3, align 4
%v4 = alloca %s.4, align 4
%v5 = alloca %s.5, align 8
br i1 undef, label %b34, label %b1
b1: ; preds = %b0
br i1 undef, label %b3, label %b2
b2: ; preds = %b1
%v6 = ptrtoint %s.0* %v0 to i32
%v7 = zext i32 %v6 to i64
%v8 = shl nuw i64 %v7, 32
%v9 = or i64 %v8, zext (i32 ptrtoint (void (i32*, i32)* @f2 to i32) to i64)
%v10 = ptrtoint %s.4* %v4 to i32
%v11 = zext i32 %v10 to i64
%v12 = shl nuw i64 %v11, 32
%v13 = or i64 %v12, zext (i32 ptrtoint (void (i32*, i32)* @f5 to i32) to i64)
%v14 = ptrtoint %s.5* %v5 to i32
%v15 = zext i32 %v14 to i64
%v16 = shl nuw i64 %v15, 32
%v17 = or i64 %v16, zext (i32 ptrtoint (void (i32*, i32)* @f6 to i32) to i64)
%v18 = ptrtoint %s.1* %v1 to i32
%v19 = zext i32 %v18 to i64
%v20 = shl nuw i64 %v19, 32
%v21 = or i64 %v20, zext (i32 ptrtoint (void (i32*, i32)* @f3 to i32) to i64)
%v22 = ptrtoint %s.2* %v2 to i32
%v23 = zext i32 %v22 to i64
%v24 = shl nuw i64 %v23, 32
%v25 = or i64 %v24, zext (i32 ptrtoint (void (i32*, i32)* @f4 to i32) to i64)
%v26 = ptrtoint %s.3* %v3 to i32
%v27 = zext i32 %v26 to i64
%v28 = shl nuw i64 %v27, 32
%v29 = or i64 %v28, zext (i32 ptrtoint (void (i32*, i32)* @f7 to i32) to i64)
%v30 = call i32* @f9(i32* nonnull null) #1
br i1 undef, label %b5, label %b4
b3: ; preds = %b1
unreachable
b4: ; preds = %b2
store i32* null, i32** null, align 4
%v31 = call zeroext i1 @f0(i32* null) #0
br i1 %v31, label %b6, label %b32
b5: ; preds = %b2
unreachable
b6: ; preds = %b4
br i1 undef, label %b7, label %b32
b7: ; preds = %b6
br i1 undef, label %b8, label %b32
b8: ; preds = %b7
br i1 undef, label %b9, label %b32
b9: ; preds = %b8
br i1 undef, label %b10, label %b32
b10: ; preds = %b9
%v32 = call zeroext i1 @f1(i32* null) #0
br i1 %v32, label %b11, label %b32
b11: ; preds = %b10
br i1 undef, label %b13, label %b12
b12: ; preds = %b11
unreachable
b13: ; preds = %b11
%v33 = call zeroext i1 @f0(i32* undef) #0
br i1 %v33, label %b14, label %b32
b14: ; preds = %b13
br i1 undef, label %b16, label %b15
b15: ; preds = %b14
unreachable
b16: ; preds = %b14
%v34 = call zeroext i1 @f1(i32* null) #0
br i1 %v34, label %b18, label %b17
b17: ; preds = %b16
unreachable
b18: ; preds = %b16
br i1 undef, label %b19, label %b32
b19: ; preds = %b18
br i1 undef, label %b26, label %b20
b20: ; preds = %b19
br i1 undef, label %b22, label %b21
b21: ; preds = %b20
br i1 undef, label %b23, label %b32
b22: ; preds = %b20
unreachable
b23: ; preds = %b21
br i1 undef, label %b24, label %b32
b24: ; preds = %b23
%v35 = call zeroext i1 @f8(i32* nonnull %a1, i32* undef, i64 undef) #1
br i1 %v35, label %b25, label %b32
b25: ; preds = %b24
%v36 = call zeroext i1 @f8(i32* nonnull %a1, i32* undef, i64 %v9) #1
unreachable
b26: ; preds = %b19
br i1 undef, label %b27, label %b32
b27: ; preds = %b26
br i1 undef, label %b28, label %b32
b28: ; preds = %b27
br i1 undef, label %b31, label %b29
b29: ; preds = %b28
%v37 = call zeroext i1 @f8(i32* nonnull %a1, i32* null, i64 %v21) #1
%v38 = call zeroext i1 @f8(i32* nonnull %a1, i32* undef, i64 %v25) #1
br i1 %v38, label %b30, label %b32
b30: ; preds = %b29
%v39 = call zeroext i1 @f8(i32* nonnull %a1, i32* undef, i64 %v29) #1
unreachable
b31: ; preds = %b28
%v40 = call zeroext i1 @f8(i32* nonnull %a1, i32* null, i64 %v13) #1
%v41 = call zeroext i1 @f8(i32* nonnull %a1, i32* undef, i64 %v17) #1
br i1 %v41, label %b33, label %b32
b32: ; preds = %b31, %b29, %b27, %b26, %b24, %b23, %b21, %b18, %b13, %b10, %b9, %b8, %b7, %b6, %b4
unreachable
b33: ; preds = %b31
store i32* %a0, i32** undef, align 4
unreachable
b34: ; preds = %b0
ret void
}
attributes #0 = { nounwind optsize }
attributes #1 = { optsize }