1; RUN: opt < %s -basicaa -gvn -S | FileCheck %s
2
3	%struct.anon = type { i32 (i32, i32, i32)*, i32, i32, [3 x i32], i8*, i8*, i8* }
4@debug = external constant i32		; <i32*> [#uses=0]
5@counters = external constant i32		; <i32*> [#uses=1]
6@trialx = external global [17 x i32]		; <[17 x i32]*> [#uses=1]
7@dummy1 = external global [7 x i32]		; <[7 x i32]*> [#uses=0]
8@dummy2 = external global [4 x i32]		; <[4 x i32]*> [#uses=0]
9@unacceptable = external global i32		; <i32*> [#uses=0]
10@isa = external global [13 x %struct.anon]		; <[13 x %struct.anon]*> [#uses=3]
11@.str = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
12@.str1 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
13@.str2 = external constant [1 x i8]		; <[1 x i8]*> [#uses=0]
14@.str3 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
15@.str4 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
16@.str5 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
17@.str6 = external constant [2 x i8]		; <[2 x i8]*> [#uses=0]
18@.str7 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
19@.str8 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
20@.str9 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
21@.str10 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
22@.str11 = external constant [2 x i8]		; <[2 x i8]*> [#uses=0]
23@.str12 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
24@.str13 = external constant [2 x i8]		; <[2 x i8]*> [#uses=0]
25@.str14 = external constant [5 x i8]		; <[5 x i8]*> [#uses=0]
26@.str15 = external constant [5 x i8]		; <[5 x i8]*> [#uses=0]
27@.str16 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
28@.str17 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
29@.str18 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
30@.str19 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
31@.str20 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
32@.str21 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
33@.str22 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
34@.str23 = external constant [5 x i8]		; <[5 x i8]*> [#uses=0]
35@.str24 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
36@.str25 = external constant [6 x i8]		; <[6 x i8]*> [#uses=0]
37@.str26 = external constant [5 x i8]		; <[5 x i8]*> [#uses=0]
38@.str27 = external constant [6 x i8]		; <[6 x i8]*> [#uses=0]
39@r = external global [17 x i32]		; <[17 x i32]*> [#uses=0]
40@.str28 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
41@.str29 = external constant [5 x i8]		; <[5 x i8]*> [#uses=0]
42@pgm = external global [5 x { i32, [3 x i32] }]		; <[5 x { i32, [3 x i32] }]*> [#uses=4]
43@.str30 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
44@.str31 = external constant [13 x i8]		; <[13 x i8]*> [#uses=0]
45@.str32 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
46@.str33 = external constant [4 x i8]		; <[4 x i8]*> [#uses=0]
47@.str34 = external constant [20 x i8]		; <[20 x i8]*> [#uses=0]
48@numi = external global i32		; <i32*> [#uses=7]
49@.str35 = external constant [10 x i8]		; <[10 x i8]*> [#uses=0]
50@counter = external global [5 x i32]		; <[5 x i32]*> [#uses=2]
51@itrialx.2510 = external global i32		; <i32*> [#uses=0]
52@.str36 = external constant [43 x i8]		; <[43 x i8]*> [#uses=0]
53@.str37 = external constant [42 x i8]		; <[42 x i8]*> [#uses=0]
54@corr_result = external global i32		; <i32*> [#uses=0]
55@.str38 = external constant [3 x i8]		; <[3 x i8]*> [#uses=0]
56@.str39 = external constant [5 x i8]		; <[5 x i8]*> [#uses=0]
57@.str40 = external constant [47 x i8]		; <[47 x i8]*> [#uses=0]
58@correct_result = external global [17 x i32]		; <[17 x i32]*> [#uses=1]
59@.str41 = external constant [46 x i8]		; <[46 x i8]*> [#uses=0]
60@.str42 = external constant [32 x i8]		; <[32 x i8]*> [#uses=0]
61@.str43 = external constant [44 x i8]		; <[44 x i8]*> [#uses=1]
62@.str44 = external constant [21 x i8]		; <[21 x i8]*> [#uses=1]
63@.str45 = external constant [12 x i8]		; <[12 x i8]*> [#uses=1]
64@.str46 = external constant [5 x i8]		; <[5 x i8]*> [#uses=1]
65@.str47 = external constant [12 x i8]		; <[12 x i8]*> [#uses=1]
66
67declare i32 @neg(i32, i32, i32)
68
69declare i32 @Not(i32, i32, i32)
70
71declare i32 @pop(i32, i32, i32)
72
73declare i32 @nlz(i32, i32, i32)
74
75declare i32 @rev(i32, i32, i32)
76
77declare i32 @add(i32, i32, i32)
78
79declare i32 @sub(i32, i32, i32)
80
81declare i32 @mul(i32, i32, i32)
82
83declare i32 @divide(i32, i32, i32)
84
85declare i32 @divu(i32, i32, i32)
86
87declare i32 @And(i32, i32, i32)
88
89declare i32 @Or(i32, i32, i32)
90
91declare i32 @Xor(i32, i32, i32)
92
93declare i32 @rotl(i32, i32, i32)
94
95declare i32 @shl(i32, i32, i32)
96
97declare i32 @shr(i32, i32, i32)
98
99declare i32 @shrs(i32, i32, i32)
100
101declare i32 @cmpeq(i32, i32, i32)
102
103declare i32 @cmplt(i32, i32, i32)
104
105declare i32 @cmpltu(i32, i32, i32)
106
107declare i32 @seleq(i32, i32, i32)
108
109declare i32 @sellt(i32, i32, i32)
110
111declare i32 @selle(i32, i32, i32)
112
113declare void @print_expr(i32)
114
115declare i32 @printf(i8*, ...)
116
117declare i32 @putchar(i32)
118
119declare void @print_pgm()
120
121declare void @simulate_one_instruction(i32)
122
123declare i32 @check(i32)
124
125declare i32 @puts(i8*)
126
127declare void @fix_operands(i32)
128
129declare void @abort()
130
131declare i32 @increment()
132
133declare i32 @search()
134
135define i32 @main(i32 %argc, i8** %argv) {
136entry:
137	%argc_addr = alloca i32		; <i32*> [#uses=1]
138	%argv_addr = alloca i8**		; <i8***> [#uses=1]
139	%retval = alloca i32, align 4		; <i32*> [#uses=2]
140	%tmp = alloca i32, align 4		; <i32*> [#uses=2]
141	%i = alloca i32, align 4		; <i32*> [#uses=21]
142	%num_sol = alloca i32, align 4		; <i32*> [#uses=4]
143	%total = alloca i32, align 4		; <i32*> [#uses=4]
144	%"alloca point" = bitcast i32 0 to i32		; <i32> [#uses=0]
145	store i32 %argc, i32* %argc_addr
146	store i8** %argv, i8*** %argv_addr
147	store i32 0, i32* %num_sol
148	store i32 1, i32* @numi
149	br label %bb91
150
151bb:		; preds = %cond_next97
152	%tmp1 = load i32, i32* @numi		; <i32> [#uses=1]
153	%tmp2 = getelementptr [44 x i8], [44 x i8]* @.str43, i32 0, i32 0		; <i8*> [#uses=1]
154	%tmp3 = call i32 (i8*, ...) @printf( i8* %tmp2, i32 %tmp1 )		; <i32> [#uses=0]
155	store i32 0, i32* %i
156	br label %bb13
157
158bb4:		; preds = %bb13
159	%tmp5 = load i32, i32* %i		; <i32> [#uses=1]
160	%tmp6 = load i32, i32* %i		; <i32> [#uses=1]
161	%tmp7 = getelementptr [17 x i32], [17 x i32]* @trialx, i32 0, i32 %tmp6		; <i32*> [#uses=1]
162	%tmp8 = load i32, i32* %tmp7		; <i32> [#uses=1]
163	%tmp9 = call i32 @userfun( i32 %tmp8 )		; <i32> [#uses=1]
164	%tmp10 = getelementptr [17 x i32], [17 x i32]* @correct_result, i32 0, i32 %tmp5		; <i32*> [#uses=1]
165	store i32 %tmp9, i32* %tmp10
166	%tmp11 = load i32, i32* %i		; <i32> [#uses=1]
167	%tmp12 = add i32 %tmp11, 1		; <i32> [#uses=1]
168	store i32 %tmp12, i32* %i
169	br label %bb13
170
171bb13:		; preds = %bb4, %bb
172	%tmp14 = load i32, i32* %i		; <i32> [#uses=1]
173	%tmp15 = icmp sle i32 %tmp14, 16		; <i1> [#uses=1]
174	%tmp1516 = zext i1 %tmp15 to i32		; <i32> [#uses=1]
175	%toBool = icmp ne i32 %tmp1516, 0		; <i1> [#uses=1]
176	br i1 %toBool, label %bb4, label %bb17
177
178bb17:		; preds = %bb13
179	store i32 0, i32* %i
180	br label %bb49
181
182bb18:		; preds = %bb49
183	%tmp19 = load i32, i32* %i		; <i32> [#uses=1]
184	%tmp20 = getelementptr [5 x { i32, [3 x i32] }], [5 x { i32, [3 x i32] }]* @pgm, i32 0, i32 %tmp19		; <{ i32, [3 x i32] }*> [#uses=1]
185	%tmp21 = getelementptr { i32, [3 x i32] }, { i32, [3 x i32] }* %tmp20, i32 0, i32 0		; <i32*> [#uses=1]
186	store i32 0, i32* %tmp21
187	%tmp22 = load i32, i32* %i		; <i32> [#uses=1]
188	%tmp23 = getelementptr [13 x %struct.anon], [13 x %struct.anon]* @isa, i32 0, i32 0		; <%struct.anon*> [#uses=1]
189	%tmp24 = getelementptr %struct.anon, %struct.anon* %tmp23, i32 0, i32 3		; <[3 x i32]*> [#uses=1]
190	%tmp25 = getelementptr [3 x i32], [3 x i32]* %tmp24, i32 0, i32 0		; <i32*> [#uses=1]
191	%tmp26 = load i32, i32* %tmp25		; <i32> [#uses=1]
192	%tmp27 = getelementptr [5 x { i32, [3 x i32] }], [5 x { i32, [3 x i32] }]* @pgm, i32 0, i32 %tmp22		; <{ i32, [3 x i32] }*> [#uses=1]
193	%tmp28 = getelementptr { i32, [3 x i32] }, { i32, [3 x i32] }* %tmp27, i32 0, i32 1		; <[3 x i32]*> [#uses=1]
194	%tmp29 = getelementptr [3 x i32], [3 x i32]* %tmp28, i32 0, i32 0		; <i32*> [#uses=1]
195	store i32 %tmp26, i32* %tmp29
196	%tmp30 = load i32, i32* %i		; <i32> [#uses=1]
197	%tmp31 = getelementptr [13 x %struct.anon], [13 x %struct.anon]* @isa, i32 0, i32 0		; <%struct.anon*> [#uses=1]
198	%tmp32 = getelementptr %struct.anon, %struct.anon* %tmp31, i32 0, i32 3		; <[3 x i32]*> [#uses=1]
199	%tmp33 = getelementptr [3 x i32], [3 x i32]* %tmp32, i32 0, i32 1		; <i32*> [#uses=1]
200	%tmp34 = load i32, i32* %tmp33		; <i32> [#uses=1]
201	%tmp35 = getelementptr [5 x { i32, [3 x i32] }], [5 x { i32, [3 x i32] }]* @pgm, i32 0, i32 %tmp30		; <{ i32, [3 x i32] }*> [#uses=1]
202	%tmp36 = getelementptr { i32, [3 x i32] }, { i32, [3 x i32] }* %tmp35, i32 0, i32 1		; <[3 x i32]*> [#uses=1]
203	%tmp37 = getelementptr [3 x i32], [3 x i32]* %tmp36, i32 0, i32 1		; <i32*> [#uses=1]
204	store i32 %tmp34, i32* %tmp37
205	%tmp38 = load i32, i32* %i		; <i32> [#uses=1]
206	%tmp39 = getelementptr [13 x %struct.anon], [13 x %struct.anon]* @isa, i32 0, i32 0		; <%struct.anon*> [#uses=1]
207	%tmp40 = getelementptr %struct.anon, %struct.anon* %tmp39, i32 0, i32 3		; <[3 x i32]*> [#uses=1]
208	%tmp41 = getelementptr [3 x i32], [3 x i32]* %tmp40, i32 0, i32 2		; <i32*> [#uses=1]
209	%tmp42 = load i32, i32* %tmp41		; <i32> [#uses=1]
210	%tmp43 = getelementptr [5 x { i32, [3 x i32] }], [5 x { i32, [3 x i32] }]* @pgm, i32 0, i32 %tmp38		; <{ i32, [3 x i32] }*> [#uses=1]
211	%tmp44 = getelementptr { i32, [3 x i32] }, { i32, [3 x i32] }* %tmp43, i32 0, i32 1		; <[3 x i32]*> [#uses=1]
212	%tmp45 = getelementptr [3 x i32], [3 x i32]* %tmp44, i32 0, i32 2		; <i32*> [#uses=1]
213	store i32 %tmp42, i32* %tmp45
214	%tmp46 = load i32, i32* %i		; <i32> [#uses=1]
215	call void @fix_operands( i32 %tmp46 )
216	%tmp47 = load i32, i32* %i		; <i32> [#uses=1]
217; CHECK: %tmp47 = phi i32 [ %tmp48, %bb18 ], [ 0, %bb17 ]
218	%tmp48 = add i32 %tmp47, 1		; <i32> [#uses=1]
219	store i32 %tmp48, i32* %i
220	br label %bb49
221
222bb49:		; preds = %bb18, %bb17
223	%tmp50 = load i32, i32* @numi		; <i32> [#uses=1]
224	%tmp51 = load i32, i32* %i		; <i32> [#uses=1]
225	%tmp52 = icmp slt i32 %tmp51, %tmp50		; <i1> [#uses=1]
226	%tmp5253 = zext i1 %tmp52 to i32		; <i32> [#uses=1]
227	%toBool54 = icmp ne i32 %tmp5253, 0		; <i1> [#uses=1]
228	br i1 %toBool54, label %bb18, label %bb55
229
230bb55:		; preds = %bb49
231	%tmp56 = call i32 @search( )		; <i32> [#uses=1]
232	store i32 %tmp56, i32* %num_sol
233	%tmp57 = getelementptr [21 x i8], [21 x i8]* @.str44, i32 0, i32 0		; <i8*> [#uses=1]
234	%tmp58 = load i32, i32* %num_sol		; <i32> [#uses=1]
235	%tmp59 = call i32 (i8*, ...) @printf( i8* %tmp57, i32 %tmp58 )		; <i32> [#uses=0]
236	%tmp60 = load i32, i32* @counters		; <i32> [#uses=1]
237	%tmp61 = icmp ne i32 %tmp60, 0		; <i1> [#uses=1]
238	%tmp6162 = zext i1 %tmp61 to i32		; <i32> [#uses=1]
239	%toBool63 = icmp ne i32 %tmp6162, 0		; <i1> [#uses=1]
240	br i1 %toBool63, label %cond_true, label %cond_next
241
242cond_true:		; preds = %bb55
243	store i32 0, i32* %total
244	%tmp64 = getelementptr [12 x i8], [12 x i8]* @.str45, i32 0, i32 0		; <i8*> [#uses=1]
245	%tmp65 = call i32 (i8*, ...) @printf( i8* %tmp64 )		; <i32> [#uses=0]
246	store i32 0, i32* %i
247	br label %bb79
248
249bb66:		; preds = %bb79
250	%tmp67 = load i32, i32* %i		; <i32> [#uses=1]
251	%tmp68 = getelementptr [5 x i32], [5 x i32]* @counter, i32 0, i32 %tmp67		; <i32*> [#uses=1]
252	%tmp69 = load i32, i32* %tmp68		; <i32> [#uses=1]
253	%tmp70 = getelementptr [5 x i8], [5 x i8]* @.str46, i32 0, i32 0		; <i8*> [#uses=1]
254	%tmp71 = call i32 (i8*, ...) @printf( i8* %tmp70, i32 %tmp69 )		; <i32> [#uses=0]
255	%tmp72 = load i32, i32* %i		; <i32> [#uses=1]
256	%tmp73 = getelementptr [5 x i32], [5 x i32]* @counter, i32 0, i32 %tmp72		; <i32*> [#uses=1]
257	%tmp74 = load i32, i32* %tmp73		; <i32> [#uses=1]
258	%tmp75 = load i32, i32* %total		; <i32> [#uses=1]
259	%tmp76 = add i32 %tmp74, %tmp75		; <i32> [#uses=1]
260	store i32 %tmp76, i32* %total
261	%tmp77 = load i32, i32* %i		; <i32> [#uses=1]
262	%tmp78 = add i32 %tmp77, 1		; <i32> [#uses=1]
263	store i32 %tmp78, i32* %i
264	br label %bb79
265
266bb79:		; preds = %bb66, %cond_true
267	%tmp80 = load i32, i32* @numi		; <i32> [#uses=1]
268	%tmp81 = load i32, i32* %i		; <i32> [#uses=1]
269	%tmp82 = icmp slt i32 %tmp81, %tmp80		; <i1> [#uses=1]
270	%tmp8283 = zext i1 %tmp82 to i32		; <i32> [#uses=1]
271	%toBool84 = icmp ne i32 %tmp8283, 0		; <i1> [#uses=1]
272	br i1 %toBool84, label %bb66, label %bb85
273
274bb85:		; preds = %bb79
275	%tmp86 = getelementptr [12 x i8], [12 x i8]* @.str47, i32 0, i32 0		; <i8*> [#uses=1]
276	%tmp87 = load i32, i32* %total		; <i32> [#uses=1]
277	%tmp88 = call i32 (i8*, ...) @printf( i8* %tmp86, i32 %tmp87 )		; <i32> [#uses=0]
278	br label %cond_next
279
280cond_next:		; preds = %bb85, %bb55
281	%tmp89 = load i32, i32* @numi		; <i32> [#uses=1]
282	%tmp90 = add i32 %tmp89, 1		; <i32> [#uses=1]
283	store i32 %tmp90, i32* @numi
284	br label %bb91
285
286bb91:		; preds = %cond_next, %entry
287	%tmp92 = load i32, i32* @numi		; <i32> [#uses=1]
288	%tmp93 = icmp sgt i32 %tmp92, 5		; <i1> [#uses=1]
289	%tmp9394 = zext i1 %tmp93 to i32		; <i32> [#uses=1]
290	%toBool95 = icmp ne i32 %tmp9394, 0		; <i1> [#uses=1]
291	br i1 %toBool95, label %cond_true96, label %cond_next97
292
293cond_true96:		; preds = %bb91
294	br label %bb102
295
296cond_next97:		; preds = %bb91
297	%tmp98 = load i32, i32* %num_sol		; <i32> [#uses=1]
298	%tmp99 = icmp eq i32 %tmp98, 0		; <i1> [#uses=1]
299	%tmp99100 = zext i1 %tmp99 to i32		; <i32> [#uses=1]
300	%toBool101 = icmp ne i32 %tmp99100, 0		; <i1> [#uses=1]
301	br i1 %toBool101, label %bb, label %bb102
302
303bb102:		; preds = %cond_next97, %cond_true96
304	store i32 0, i32* %tmp
305	%tmp103 = load i32, i32* %tmp		; <i32> [#uses=1]
306	store i32 %tmp103, i32* %retval
307	br label %return
308
309return:		; preds = %bb102
310	%retval104 = load i32, i32* %retval		; <i32> [#uses=1]
311	ret i32 %retval104
312}
313
314declare i32 @userfun(i32)
315