1; RUN: opt -loop-reduce -S < %s | FileCheck %s
2; Test compile time should be <1sec (no hang).
3target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
4
5; Function Attrs: argmemonly nounwind
6declare void @llvm.lifetime.start.p0i8(i64, i8* nocapture) #1
7
8; Function Attrs: argmemonly nounwind
9declare void @llvm.lifetime.end.p0i8(i64, i8* nocapture) #1
10
11; Function Attrs: nounwind readnone uwtable
12define dso_local i32 @foo(i32 %arg, i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6) local_unnamed_addr #3 {
13; CHECK-LABEL: @foo(
14; CHECK:       bb33:
15; CHECK:       lsr.iv
16; CHECK:       bb58:
17; CHECK:       lsr.iv
18; CHECK:       bb81:
19; CHECK:       lsr.iv
20; CHECK:       bb104:
21; CHECK:       lsr.iv
22; CHECK:       bb127:
23; CHECK:       lsr.iv
24; CHECK:       bb150:
25; CHECK:       lsr.iv
26; CHECK:       bb173:
27; CHECK:       lsr.iv
28; CHECK:       bb196:
29; CHECK:       lsr.iv
30; CHECK:       bb219:
31; CHECK:       lsr.iv
32; CHECK:       bb242:
33; CHECK:       lsr.iv
34; CHECK:       bb265:
35; CHECK:       lsr.iv
36; CHECK:       bb288:
37; CHECK:       lsr.iv
38; CHECK:       bb311:
39; CHECK:       lsr.iv
40; CHECK:       bb340:
41; CHECK:       lsr.iv
42; CHECK:       bb403:
43; CHECK:       lsr.iv
44; CHECK:       bb433:
45; CHECK:       lsr.iv
46; CHECK:       bb567:
47; CHECK:       lsr.iv
48; CHECK:       bb611:
49; CHECK:       lsr.iv
50; CHECK:       bb655:
51; CHECK:       lsr.iv
52; CHECK:       bb699:
53; CHECK:       lsr.iv
54; CHECK:       bb743:
55; CHECK:       lsr.iv
56; CHECK:       bb787:
57; CHECK:       lsr.iv
58; CHECK:       bb831:
59; CHECK:       lsr.iv
60; CHECK:       bb875:
61; CHECK:       lsr.iv
62; CHECK:       bb919:
63; CHECK:       lsr.iv
64; CHECK:       bb963:
65; CHECK:       lsr.iv
66; CHECK:       bb1007:
67; CHECK:       lsr.iv
68; CHECK:    ret
69;
70bb:
71  %tmp = alloca [100 x i32], align 16
72  %tmp7 = alloca [100 x i32], align 16
73  %tmp8 = alloca [100 x i32], align 16
74  %tmp9 = alloca [100 x [100 x i32]], align 16
75  %tmp10 = alloca [100 x i32], align 16
76  %tmp11 = alloca [100 x [100 x i32]], align 16
77  %tmp12 = alloca [100 x i32], align 16
78  %tmp13 = alloca [100 x i32], align 16
79  %tmp14 = alloca [100 x [100 x i32]], align 16
80  %tmp15 = alloca [100 x i32], align 16
81  %tmp16 = alloca [100 x [100 x i32]], align 16
82  %tmp17 = alloca [100 x [100 x i32]], align 16
83  %tmp18 = alloca [100 x [100 x i32]], align 16
84  %tmp19 = bitcast [100 x i32]* %tmp to i8*
85  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp19) #4
86  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp19, i8 0, i64 400, i1 false)
87  %tmp20 = bitcast [100 x i32]* %tmp7 to i8*
88  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp20) #4
89  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp20, i8 0, i64 400, i1 false)
90  %tmp21 = bitcast [100 x i32]* %tmp8 to i8*
91  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp21) #4
92  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp21, i8 0, i64 400, i1 false)
93  %tmp22 = bitcast [100 x [100 x i32]]* %tmp9 to i8*
94  call void @llvm.lifetime.start.p0i8(i64 40000, i8* nonnull %tmp22) #4
95  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp22, i8 0, i64 40000, i1 false)
96  %tmp23 = bitcast [100 x i32]* %tmp10 to i8*
97  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp23) #4
98  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp23, i8 0, i64 400, i1 false)
99  %tmp24 = bitcast [100 x [100 x i32]]* %tmp11 to i8*
100  call void @llvm.lifetime.start.p0i8(i64 40000, i8* nonnull %tmp24) #4
101  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp24, i8 0, i64 40000, i1 false)
102  %tmp25 = bitcast [100 x i32]* %tmp12 to i8*
103  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp25) #4
104  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp25, i8 0, i64 400, i1 false)
105  %tmp26 = bitcast [100 x i32]* %tmp13 to i8*
106  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp26) #4
107  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp26, i8 0, i64 400, i1 false)
108  %tmp27 = bitcast [100 x [100 x i32]]* %tmp14 to i8*
109  call void @llvm.lifetime.start.p0i8(i64 40000, i8* nonnull %tmp27) #4
110  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp27, i8 0, i64 40000, i1 false)
111  %tmp28 = bitcast [100 x i32]* %tmp15 to i8*
112  call void @llvm.lifetime.start.p0i8(i64 400, i8* nonnull %tmp28) #4
113  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp28, i8 0, i64 400, i1 false)
114  %tmp29 = bitcast [100 x [100 x i32]]* %tmp16 to i8*
115  call void @llvm.lifetime.start.p0i8(i64 40000, i8* nonnull %tmp29) #4
116  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp29, i8 0, i64 40000, i1 false)
117  %tmp30 = bitcast [100 x [100 x i32]]* %tmp17 to i8*
118  call void @llvm.lifetime.start.p0i8(i64 40000, i8* nonnull %tmp30) #4
119  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp30, i8 0, i64 40000, i1 false)
120  %tmp31 = bitcast [100 x [100 x i32]]* %tmp18 to i8*
121  call void @llvm.lifetime.start.p0i8(i64 40000, i8* nonnull %tmp31) #4
122  call void @llvm.memset.p0i8.i64(i8* nonnull align 16 %tmp31, i8 0, i64 40000, i1 false)
123  %tmp32 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 3
124  br label %bb33
125
126bb33:                                             ; preds = %bb33, %bb
127  %tmp34 = phi i64 [ 0, %bb ], [ %tmp54, %bb33 ]
128  %tmp35 = trunc i64 %tmp34 to i32
129  %tmp36 = add i32 %tmp35, 48
130  %tmp37 = urem i32 %tmp36, 101
131  %tmp38 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp34
132  store i32 %tmp37, i32* %tmp38, align 16
133  %tmp39 = or i64 %tmp34, 1
134  %tmp40 = trunc i64 %tmp39 to i32
135  %tmp41 = sub i32 48, %tmp40
136  %tmp42 = urem i32 %tmp41, 101
137  %tmp43 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp39
138  store i32 %tmp42, i32* %tmp43, align 4
139  %tmp44 = or i64 %tmp34, 2
140  %tmp45 = trunc i64 %tmp44 to i32
141  %tmp46 = add i32 %tmp45, 48
142  %tmp47 = urem i32 %tmp46, 101
143  %tmp48 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp44
144  store i32 %tmp47, i32* %tmp48, align 8
145  %tmp49 = or i64 %tmp34, 3
146  %tmp50 = trunc i64 %tmp49 to i32
147  %tmp51 = sub i32 48, %tmp50
148  %tmp52 = urem i32 %tmp51, 101
149  %tmp53 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp49
150  store i32 %tmp52, i32* %tmp53, align 4
151  %tmp54 = add nuw nsw i64 %tmp34, 4
152  %tmp55 = icmp eq i64 %tmp54, 100
153  br i1 %tmp55, label %bb56, label %bb33
154
155bb56:                                             ; preds = %bb33
156  %tmp57 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 88, i64 91
157  br label %bb58
158
159bb58:                                             ; preds = %bb58, %bb56
160  %tmp59 = phi i64 [ 0, %bb56 ], [ %tmp79, %bb58 ]
161  %tmp60 = trunc i64 %tmp59 to i32
162  %tmp61 = add i32 %tmp60, 83
163  %tmp62 = urem i32 %tmp61, 101
164  %tmp63 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp59
165  store i32 %tmp62, i32* %tmp63, align 16
166  %tmp64 = or i64 %tmp59, 1
167  %tmp65 = trunc i64 %tmp64 to i32
168  %tmp66 = sub i32 83, %tmp65
169  %tmp67 = urem i32 %tmp66, 101
170  %tmp68 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp64
171  store i32 %tmp67, i32* %tmp68, align 4
172  %tmp69 = or i64 %tmp59, 2
173  %tmp70 = trunc i64 %tmp69 to i32
174  %tmp71 = add i32 %tmp70, 83
175  %tmp72 = urem i32 %tmp71, 101
176  %tmp73 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp69
177  store i32 %tmp72, i32* %tmp73, align 8
178  %tmp74 = or i64 %tmp59, 3
179  %tmp75 = trunc i64 %tmp74 to i32
180  %tmp76 = sub i32 83, %tmp75
181  %tmp77 = urem i32 %tmp76, 101
182  %tmp78 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp74
183  store i32 %tmp77, i32* %tmp78, align 4
184  %tmp79 = add nuw nsw i64 %tmp59, 4
185  %tmp80 = icmp eq i64 %tmp79, 100
186  br i1 %tmp80, label %bb81, label %bb58
187
188bb81:                                             ; preds = %bb81, %bb58
189  %tmp82 = phi i64 [ %tmp102, %bb81 ], [ 0, %bb58 ]
190  %tmp83 = trunc i64 %tmp82 to i32
191  %tmp84 = add i32 %tmp83, 15
192  %tmp85 = urem i32 %tmp84, 101
193  %tmp86 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp82
194  store i32 %tmp85, i32* %tmp86, align 16
195  %tmp87 = or i64 %tmp82, 1
196  %tmp88 = trunc i64 %tmp87 to i32
197  %tmp89 = sub i32 15, %tmp88
198  %tmp90 = urem i32 %tmp89, 101
199  %tmp91 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp87
200  store i32 %tmp90, i32* %tmp91, align 4
201  %tmp92 = or i64 %tmp82, 2
202  %tmp93 = trunc i64 %tmp92 to i32
203  %tmp94 = add i32 %tmp93, 15
204  %tmp95 = urem i32 %tmp94, 101
205  %tmp96 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp92
206  store i32 %tmp95, i32* %tmp96, align 8
207  %tmp97 = or i64 %tmp82, 3
208  %tmp98 = trunc i64 %tmp97 to i32
209  %tmp99 = sub i32 15, %tmp98
210  %tmp100 = urem i32 %tmp99, 101
211  %tmp101 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp97
212  store i32 %tmp100, i32* %tmp101, align 4
213  %tmp102 = add nuw nsw i64 %tmp82, 4
214  %tmp103 = icmp eq i64 %tmp102, 100
215  br i1 %tmp103, label %bb104, label %bb81
216
217bb104:                                            ; preds = %bb104, %bb81
218  %tmp105 = phi i64 [ %tmp125, %bb104 ], [ 0, %bb81 ]
219  %tmp106 = trunc i64 %tmp105 to i32
220  %tmp107 = add i32 %tmp106, 60
221  %tmp108 = urem i32 %tmp107, 101
222  %tmp109 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp105
223  store i32 %tmp108, i32* %tmp109, align 16
224  %tmp110 = or i64 %tmp105, 1
225  %tmp111 = trunc i64 %tmp110 to i32
226  %tmp112 = sub i32 60, %tmp111
227  %tmp113 = urem i32 %tmp112, 101
228  %tmp114 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp110
229  store i32 %tmp113, i32* %tmp114, align 4
230  %tmp115 = or i64 %tmp105, 2
231  %tmp116 = trunc i64 %tmp115 to i32
232  %tmp117 = add i32 %tmp116, 60
233  %tmp118 = urem i32 %tmp117, 101
234  %tmp119 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp115
235  store i32 %tmp118, i32* %tmp119, align 8
236  %tmp120 = or i64 %tmp105, 3
237  %tmp121 = trunc i64 %tmp120 to i32
238  %tmp122 = sub i32 60, %tmp121
239  %tmp123 = urem i32 %tmp122, 101
240  %tmp124 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp120
241  store i32 %tmp123, i32* %tmp124, align 4
242  %tmp125 = add nuw nsw i64 %tmp105, 4
243  %tmp126 = icmp eq i64 %tmp125, 10000
244  br i1 %tmp126, label %bb127, label %bb104
245
246bb127:                                            ; preds = %bb127, %bb104
247  %tmp128 = phi i64 [ %tmp148, %bb127 ], [ 0, %bb104 ]
248  %tmp129 = trunc i64 %tmp128 to i32
249  %tmp130 = add i32 %tmp129, 87
250  %tmp131 = urem i32 %tmp130, 101
251  %tmp132 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp128
252  store i32 %tmp131, i32* %tmp132, align 16
253  %tmp133 = or i64 %tmp128, 1
254  %tmp134 = trunc i64 %tmp133 to i32
255  %tmp135 = sub i32 87, %tmp134
256  %tmp136 = urem i32 %tmp135, 101
257  %tmp137 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp133
258  store i32 %tmp136, i32* %tmp137, align 4
259  %tmp138 = or i64 %tmp128, 2
260  %tmp139 = trunc i64 %tmp138 to i32
261  %tmp140 = add i32 %tmp139, 87
262  %tmp141 = urem i32 %tmp140, 101
263  %tmp142 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp138
264  store i32 %tmp141, i32* %tmp142, align 8
265  %tmp143 = or i64 %tmp128, 3
266  %tmp144 = trunc i64 %tmp143 to i32
267  %tmp145 = sub i32 87, %tmp144
268  %tmp146 = urem i32 %tmp145, 101
269  %tmp147 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp143
270  store i32 %tmp146, i32* %tmp147, align 4
271  %tmp148 = add nuw nsw i64 %tmp128, 4
272  %tmp149 = icmp eq i64 %tmp148, 100
273  br i1 %tmp149, label %bb150, label %bb127
274
275bb150:                                            ; preds = %bb150, %bb127
276  %tmp151 = phi i64 [ %tmp171, %bb150 ], [ 0, %bb127 ]
277  %tmp152 = trunc i64 %tmp151 to i32
278  %tmp153 = add i32 %tmp152, 36
279  %tmp154 = urem i32 %tmp153, 101
280  %tmp155 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp151
281  store i32 %tmp154, i32* %tmp155, align 16
282  %tmp156 = or i64 %tmp151, 1
283  %tmp157 = trunc i64 %tmp156 to i32
284  %tmp158 = sub i32 36, %tmp157
285  %tmp159 = urem i32 %tmp158, 101
286  %tmp160 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp156
287  store i32 %tmp159, i32* %tmp160, align 4
288  %tmp161 = or i64 %tmp151, 2
289  %tmp162 = trunc i64 %tmp161 to i32
290  %tmp163 = add i32 %tmp162, 36
291  %tmp164 = urem i32 %tmp163, 101
292  %tmp165 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp161
293  store i32 %tmp164, i32* %tmp165, align 8
294  %tmp166 = or i64 %tmp151, 3
295  %tmp167 = trunc i64 %tmp166 to i32
296  %tmp168 = sub i32 36, %tmp167
297  %tmp169 = urem i32 %tmp168, 101
298  %tmp170 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp166
299  store i32 %tmp169, i32* %tmp170, align 4
300  %tmp171 = add nuw nsw i64 %tmp151, 4
301  %tmp172 = icmp eq i64 %tmp171, 10000
302  br i1 %tmp172, label %bb173, label %bb150
303
304bb173:                                            ; preds = %bb173, %bb150
305  %tmp174 = phi i64 [ %tmp194, %bb173 ], [ 0, %bb150 ]
306  %tmp175 = trunc i64 %tmp174 to i32
307  %tmp176 = add i32 %tmp175, 27
308  %tmp177 = urem i32 %tmp176, 101
309  %tmp178 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp174
310  store i32 %tmp177, i32* %tmp178, align 16
311  %tmp179 = or i64 %tmp174, 1
312  %tmp180 = trunc i64 %tmp179 to i32
313  %tmp181 = sub i32 27, %tmp180
314  %tmp182 = urem i32 %tmp181, 101
315  %tmp183 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp179
316  store i32 %tmp182, i32* %tmp183, align 4
317  %tmp184 = or i64 %tmp174, 2
318  %tmp185 = trunc i64 %tmp184 to i32
319  %tmp186 = add i32 %tmp185, 27
320  %tmp187 = urem i32 %tmp186, 101
321  %tmp188 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp184
322  store i32 %tmp187, i32* %tmp188, align 8
323  %tmp189 = or i64 %tmp174, 3
324  %tmp190 = trunc i64 %tmp189 to i32
325  %tmp191 = sub i32 27, %tmp190
326  %tmp192 = urem i32 %tmp191, 101
327  %tmp193 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp189
328  store i32 %tmp192, i32* %tmp193, align 4
329  %tmp194 = add nuw nsw i64 %tmp174, 4
330  %tmp195 = icmp eq i64 %tmp194, 100
331  br i1 %tmp195, label %bb196, label %bb173
332
333bb196:                                            ; preds = %bb196, %bb173
334  %tmp197 = phi i64 [ %tmp217, %bb196 ], [ 0, %bb173 ]
335  %tmp198 = trunc i64 %tmp197 to i32
336  %tmp199 = add i32 %tmp198, 40
337  %tmp200 = urem i32 %tmp199, 101
338  %tmp201 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp197
339  store i32 %tmp200, i32* %tmp201, align 16
340  %tmp202 = or i64 %tmp197, 1
341  %tmp203 = trunc i64 %tmp202 to i32
342  %tmp204 = sub i32 40, %tmp203
343  %tmp205 = urem i32 %tmp204, 101
344  %tmp206 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp202
345  store i32 %tmp205, i32* %tmp206, align 4
346  %tmp207 = or i64 %tmp197, 2
347  %tmp208 = trunc i64 %tmp207 to i32
348  %tmp209 = add i32 %tmp208, 40
349  %tmp210 = urem i32 %tmp209, 101
350  %tmp211 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp207
351  store i32 %tmp210, i32* %tmp211, align 8
352  %tmp212 = or i64 %tmp197, 3
353  %tmp213 = trunc i64 %tmp212 to i32
354  %tmp214 = sub i32 40, %tmp213
355  %tmp215 = urem i32 %tmp214, 101
356  %tmp216 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp212
357  store i32 %tmp215, i32* %tmp216, align 4
358  %tmp217 = add nuw nsw i64 %tmp197, 4
359  %tmp218 = icmp eq i64 %tmp217, 100
360  br i1 %tmp218, label %bb219, label %bb196
361
362bb219:                                            ; preds = %bb219, %bb196
363  %tmp220 = phi i64 [ %tmp240, %bb219 ], [ 0, %bb196 ]
364  %tmp221 = trunc i64 %tmp220 to i32
365  %tmp222 = add i32 %tmp221, 84
366  %tmp223 = urem i32 %tmp222, 101
367  %tmp224 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp220
368  store i32 %tmp223, i32* %tmp224, align 16
369  %tmp225 = or i64 %tmp220, 1
370  %tmp226 = trunc i64 %tmp225 to i32
371  %tmp227 = sub i32 84, %tmp226
372  %tmp228 = urem i32 %tmp227, 101
373  %tmp229 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp225
374  store i32 %tmp228, i32* %tmp229, align 4
375  %tmp230 = or i64 %tmp220, 2
376  %tmp231 = trunc i64 %tmp230 to i32
377  %tmp232 = add i32 %tmp231, 84
378  %tmp233 = urem i32 %tmp232, 101
379  %tmp234 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp230
380  store i32 %tmp233, i32* %tmp234, align 8
381  %tmp235 = or i64 %tmp220, 3
382  %tmp236 = trunc i64 %tmp235 to i32
383  %tmp237 = sub i32 84, %tmp236
384  %tmp238 = urem i32 %tmp237, 101
385  %tmp239 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp235
386  store i32 %tmp238, i32* %tmp239, align 4
387  %tmp240 = add nuw nsw i64 %tmp220, 4
388  %tmp241 = icmp eq i64 %tmp240, 10000
389  br i1 %tmp241, label %bb242, label %bb219
390
391bb242:                                            ; preds = %bb242, %bb219
392  %tmp243 = phi i64 [ %tmp263, %bb242 ], [ 0, %bb219 ]
393  %tmp244 = trunc i64 %tmp243 to i32
394  %tmp245 = add i32 %tmp244, 94
395  %tmp246 = urem i32 %tmp245, 101
396  %tmp247 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp243
397  store i32 %tmp246, i32* %tmp247, align 16
398  %tmp248 = or i64 %tmp243, 1
399  %tmp249 = trunc i64 %tmp248 to i32
400  %tmp250 = sub i32 94, %tmp249
401  %tmp251 = urem i32 %tmp250, 101
402  %tmp252 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp248
403  store i32 %tmp251, i32* %tmp252, align 4
404  %tmp253 = or i64 %tmp243, 2
405  %tmp254 = trunc i64 %tmp253 to i32
406  %tmp255 = add i32 %tmp254, 94
407  %tmp256 = urem i32 %tmp255, 101
408  %tmp257 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp253
409  store i32 %tmp256, i32* %tmp257, align 8
410  %tmp258 = or i64 %tmp243, 3
411  %tmp259 = trunc i64 %tmp258 to i32
412  %tmp260 = sub i32 94, %tmp259
413  %tmp261 = urem i32 %tmp260, 101
414  %tmp262 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp258
415  store i32 %tmp261, i32* %tmp262, align 4
416  %tmp263 = add nuw nsw i64 %tmp243, 4
417  %tmp264 = icmp eq i64 %tmp263, 100
418  br i1 %tmp264, label %bb265, label %bb242
419
420bb265:                                            ; preds = %bb265, %bb242
421  %tmp266 = phi i64 [ %tmp286, %bb265 ], [ 0, %bb242 ]
422  %tmp267 = trunc i64 %tmp266 to i32
423  %tmp268 = add i32 %tmp267, 92
424  %tmp269 = urem i32 %tmp268, 101
425  %tmp270 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp266
426  store i32 %tmp269, i32* %tmp270, align 16
427  %tmp271 = or i64 %tmp266, 1
428  %tmp272 = trunc i64 %tmp271 to i32
429  %tmp273 = sub i32 92, %tmp272
430  %tmp274 = urem i32 %tmp273, 101
431  %tmp275 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp271
432  store i32 %tmp274, i32* %tmp275, align 4
433  %tmp276 = or i64 %tmp266, 2
434  %tmp277 = trunc i64 %tmp276 to i32
435  %tmp278 = add i32 %tmp277, 92
436  %tmp279 = urem i32 %tmp278, 101
437  %tmp280 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp276
438  store i32 %tmp279, i32* %tmp280, align 8
439  %tmp281 = or i64 %tmp266, 3
440  %tmp282 = trunc i64 %tmp281 to i32
441  %tmp283 = sub i32 92, %tmp282
442  %tmp284 = urem i32 %tmp283, 101
443  %tmp285 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp281
444  store i32 %tmp284, i32* %tmp285, align 4
445  %tmp286 = add nuw nsw i64 %tmp266, 4
446  %tmp287 = icmp eq i64 %tmp286, 10000
447  br i1 %tmp287, label %bb288, label %bb265
448
449bb288:                                            ; preds = %bb288, %bb265
450  %tmp289 = phi i64 [ %tmp309, %bb288 ], [ 0, %bb265 ]
451  %tmp290 = trunc i64 %tmp289 to i32
452  %tmp291 = add i32 %tmp290, 87
453  %tmp292 = urem i32 %tmp291, 101
454  %tmp293 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp289
455  store i32 %tmp292, i32* %tmp293, align 16
456  %tmp294 = or i64 %tmp289, 1
457  %tmp295 = trunc i64 %tmp294 to i32
458  %tmp296 = sub i32 87, %tmp295
459  %tmp297 = urem i32 %tmp296, 101
460  %tmp298 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp294
461  store i32 %tmp297, i32* %tmp298, align 4
462  %tmp299 = or i64 %tmp289, 2
463  %tmp300 = trunc i64 %tmp299 to i32
464  %tmp301 = add i32 %tmp300, 87
465  %tmp302 = urem i32 %tmp301, 101
466  %tmp303 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp299
467  store i32 %tmp302, i32* %tmp303, align 8
468  %tmp304 = or i64 %tmp289, 3
469  %tmp305 = trunc i64 %tmp304 to i32
470  %tmp306 = sub i32 87, %tmp305
471  %tmp307 = urem i32 %tmp306, 101
472  %tmp308 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp304
473  store i32 %tmp307, i32* %tmp308, align 4
474  %tmp309 = add nuw nsw i64 %tmp289, 4
475  %tmp310 = icmp eq i64 %tmp309, 10000
476  br i1 %tmp310, label %bb311, label %bb288
477
478bb311:                                            ; preds = %bb311, %bb288
479  %tmp312 = phi i64 [ %tmp332, %bb311 ], [ 0, %bb288 ]
480  %tmp313 = trunc i64 %tmp312 to i32
481  %tmp314 = add i32 %tmp313, 28
482  %tmp315 = urem i32 %tmp314, 101
483  %tmp316 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp312
484  store i32 %tmp315, i32* %tmp316, align 16
485  %tmp317 = or i64 %tmp312, 1
486  %tmp318 = trunc i64 %tmp317 to i32
487  %tmp319 = sub i32 28, %tmp318
488  %tmp320 = urem i32 %tmp319, 101
489  %tmp321 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp317
490  store i32 %tmp320, i32* %tmp321, align 4
491  %tmp322 = or i64 %tmp312, 2
492  %tmp323 = trunc i64 %tmp322 to i32
493  %tmp324 = add i32 %tmp323, 28
494  %tmp325 = urem i32 %tmp324, 101
495  %tmp326 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp322
496  store i32 %tmp325, i32* %tmp326, align 8
497  %tmp327 = or i64 %tmp312, 3
498  %tmp328 = trunc i64 %tmp327 to i32
499  %tmp329 = sub i32 28, %tmp328
500  %tmp330 = urem i32 %tmp329, 101
501  %tmp331 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp327
502  store i32 %tmp330, i32* %tmp331, align 4
503  %tmp332 = add nuw nsw i64 %tmp312, 4
504  %tmp333 = icmp eq i64 %tmp332, 10000
505  br i1 %tmp333, label %bb334, label %bb311
506
507bb334:                                            ; preds = %bb311
508  %tmp335 = sub i32 87, %arg
509  %tmp336 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 69
510  %tmp337 = load i32, i32* %tmp336, align 4
511  %tmp338 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 68
512  %tmp339 = load i32, i32* %tmp338, align 16
513  br label %bb340
514
515bb340:                                            ; preds = %bb340, %bb334
516  %tmp341 = phi i32 [ %tmp339, %bb334 ], [ %tmp373, %bb340 ]
517  %tmp342 = phi i32 [ %tmp337, %bb334 ], [ %tmp379, %bb340 ]
518  %tmp343 = phi i64 [ 68, %bb334 ], [ %tmp371, %bb340 ]
519  %tmp344 = phi i32 [ %tmp335, %bb334 ], [ %tmp382, %bb340 ]
520  %tmp345 = phi i32 [ %arg2, %bb334 ], [ %tmp380, %bb340 ]
521  %tmp346 = add nsw i64 %tmp343, -1
522  %tmp347 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp346
523  %tmp348 = load i32, i32* %tmp347, align 4
524  %tmp349 = add nuw nsw i64 %tmp343, 1
525  %tmp350 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp349
526  %tmp351 = sub i32 %tmp342, %tmp348
527  store i32 %tmp351, i32* %tmp350, align 4
528  %tmp352 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp343
529  %tmp353 = load i32, i32* %tmp352, align 4
530  %tmp354 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp343
531  %tmp355 = add i32 %tmp341, %tmp353
532  store i32 %tmp355, i32* %tmp354, align 4
533  %tmp356 = add i32 %tmp345, -1
534  %tmp357 = sub i32 %tmp344, %tmp345
535  %tmp358 = sub i32 %tmp357, %tmp351
536  %tmp359 = add nsw i64 %tmp343, -2
537  %tmp360 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp359
538  %tmp361 = load i32, i32* %tmp360, align 4
539  %tmp362 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp343
540  %tmp363 = sub i32 %tmp355, %tmp361
541  store i32 %tmp363, i32* %tmp362, align 4
542  %tmp364 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp346
543  %tmp365 = load i32, i32* %tmp364, align 4
544  %tmp366 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp346
545  %tmp367 = add i32 %tmp348, %tmp365
546  store i32 %tmp367, i32* %tmp366, align 4
547  %tmp368 = add i32 %tmp345, -2
548  %tmp369 = sub i32 %tmp358, %tmp356
549  %tmp370 = sub i32 %tmp369, %tmp363
550  %tmp371 = add nsw i64 %tmp343, -3
551  %tmp372 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp371
552  %tmp373 = load i32, i32* %tmp372, align 4
553  %tmp374 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp346
554  %tmp375 = sub i32 %tmp367, %tmp373
555  store i32 %tmp375, i32* %tmp374, align 4
556  %tmp376 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp359
557  %tmp377 = load i32, i32* %tmp376, align 4
558  %tmp378 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp359
559  %tmp379 = add i32 %tmp361, %tmp377
560  store i32 %tmp379, i32* %tmp378, align 4
561  %tmp380 = add i32 %tmp345, -3
562  %tmp381 = sub i32 %tmp370, %tmp368
563  %tmp382 = sub i32 %tmp381, %tmp375
564  %tmp383 = icmp ugt i64 %tmp371, 2
565  br i1 %tmp383, label %bb340, label %bb384
566
567bb384:                                            ; preds = %bb340
568  %tmp385 = add i32 %arg2, -66
569  %tmp386 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 52
570  %tmp387 = load i32, i32* %tmp386, align 16
571  store i32 %tmp387, i32* %tmp32, align 4
572  %tmp388 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 97
573  %tmp389 = load i32, i32* %tmp388, align 4
574  %tmp390 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 31
575  %tmp391 = load i32, i32* %tmp390, align 4
576  %tmp392 = icmp eq i32 %tmp389, %tmp391
577  br i1 %tmp392, label %bb478, label %bb393
578
579bb393:                                            ; preds = %bb384
580  %tmp394 = sub i32 -79, %tmp382
581  %tmp395 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 2
582  %tmp396 = bitcast i32* %tmp395 to i8*
583  %tmp397 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 2
584  %tmp398 = bitcast i32* %tmp397 to i8*
585  call void @llvm.memcpy.p0i8.p0i8.i64(i8* nonnull align 8 %tmp396, i8* nonnull align 8 %tmp398, i64 304, i1 false)
586  br label %bb399
587
588bb399:                                            ; preds = %bb424, %bb393
589  %tmp400 = phi i64 [ 77, %bb393 ], [ %tmp425, %bb424 ]
590  br label %bb403
591
592bb401:                                            ; preds = %bb424
593  %tmp402 = add i32 %arg2, 3
594  br label %bb433
595
596bb403:                                            ; preds = %bb403, %bb399
597  %tmp404 = phi i64 [ 1, %bb399 ], [ %tmp414, %bb403 ]
598  %tmp405 = add nuw nsw i64 %tmp404, 1
599  %tmp406 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 %tmp404, i64 %tmp405
600  %tmp407 = load i32, i32* %tmp406, align 4
601  %tmp408 = add i32 %tmp394, %tmp407
602  store i32 %tmp408, i32* %tmp406, align 4
603  %tmp409 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 %tmp404, i64 %tmp405
604  %tmp410 = load i32, i32* %tmp409, align 4
605  %tmp411 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp405
606  %tmp412 = load i32, i32* %tmp411, align 4
607  %tmp413 = add i32 %tmp412, %tmp410
608  store i32 %tmp413, i32* %tmp411, align 4
609  %tmp414 = add nuw nsw i64 %tmp404, 2
610  %tmp415 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 %tmp405, i64 %tmp414
611  %tmp416 = load i32, i32* %tmp415, align 4
612  %tmp417 = add i32 %tmp394, %tmp416
613  store i32 %tmp417, i32* %tmp415, align 4
614  %tmp418 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 %tmp405, i64 %tmp414
615  %tmp419 = load i32, i32* %tmp418, align 4
616  %tmp420 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp414
617  %tmp421 = load i32, i32* %tmp420, align 4
618  %tmp422 = add i32 %tmp421, %tmp419
619  store i32 %tmp422, i32* %tmp420, align 4
620  %tmp423 = icmp eq i64 %tmp414, 47
621  br i1 %tmp423, label %bb424, label %bb403
622
623bb424:                                            ; preds = %bb403
624  %tmp425 = add nsw i64 %tmp400, -1
625  %tmp426 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp425
626  %tmp427 = load i32, i32* %tmp426, align 4
627  %tmp428 = add i32 %tmp427, 2
628  %tmp429 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp425
629  %tmp430 = load i32, i32* %tmp429, align 4
630  %tmp431 = mul i32 %tmp430, %tmp428
631  store i32 %tmp431, i32* %tmp429, align 4
632  %tmp432 = icmp ugt i64 %tmp425, 1
633  br i1 %tmp432, label %bb399, label %bb401
634
635bb433:                                            ; preds = %bb475, %bb401
636  %tmp434 = phi i64 [ 2, %bb401 ], [ %tmp437, %bb475 ]
637  %tmp435 = phi i32 [ 2, %bb401 ], [ %tmp476, %bb475 ]
638  %tmp436 = add nsw i64 %tmp434, -1
639  %tmp437 = add nuw nsw i64 %tmp434, 1
640  %tmp438 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 %tmp437, i64 %tmp434
641  %tmp439 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 %tmp436, i64 %tmp437
642  %tmp440 = mul i32 %tmp435, 47
643  br label %bb441
644
645bb441:                                            ; preds = %bb473, %bb433
646  %tmp442 = phi i64 [ 1, %bb433 ], [ %tmp450, %bb473 ]
647  %tmp443 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp442
648  %tmp444 = load i32, i32* %tmp443, align 4
649  %tmp445 = add nsw i64 %tmp442, -1
650  %tmp446 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp445
651  %tmp447 = load i32, i32* %tmp446, align 4
652  %tmp448 = xor i32 %tmp444, -1
653  %tmp449 = add i32 %tmp447, %tmp448
654  store i32 %tmp449, i32* %tmp446, align 4
655  %tmp450 = add nuw nsw i64 %tmp442, 1
656  %tmp451 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 %tmp436, i64 %tmp450
657  %tmp452 = load i32, i32* %tmp451, align 4
658  %tmp453 = mul i32 %tmp452, 91
659  %tmp454 = icmp eq i32 %tmp453, -30
660  br i1 %tmp454, label %bb455, label %bb473
661
662bb455:                                            ; preds = %bb441
663  %tmp456 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp442
664  %tmp457 = load i32, i32* %tmp456, align 4
665  %tmp458 = icmp ugt i32 %tmp457, %tmp402
666  br i1 %tmp458, label %bb459, label %bb473
667
668bb459:                                            ; preds = %bb455
669  %tmp460 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 %tmp445, i64 %tmp436
670  store i32 %tmp387, i32* %tmp460, align 4
671  %tmp461 = load i32, i32* %tmp57, align 4
672  %tmp462 = load i32, i32* %tmp438, align 4
673  %tmp463 = add i32 %tmp462, %tmp461
674  %tmp464 = load i32, i32* %tmp439, align 4
675  %tmp465 = add i32 %tmp464, 68
676  %tmp466 = icmp eq i32 %tmp463, %tmp465
677  br i1 %tmp466, label %bb471, label %bb467
678
679bb467:                                            ; preds = %bb459
680  %tmp468 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp450
681  %tmp469 = load i32, i32* %tmp468, align 4
682  %tmp470 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp445
683  store i32 %tmp469, i32* %tmp470, align 4
684  br label %bb473
685
686bb471:                                            ; preds = %bb459
687  %tmp472 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 %tmp437, i64 %tmp445
688  store i32 %tmp440, i32* %tmp472, align 4
689  br label %bb473
690
691bb473:                                            ; preds = %bb471, %bb467, %bb455, %bb441
692  %tmp474 = icmp eq i64 %tmp450, 13
693  br i1 %tmp474, label %bb475, label %bb441
694
695bb475:                                            ; preds = %bb473
696  %tmp476 = add nuw nsw i32 %tmp435, 1
697  %tmp477 = icmp eq i64 %tmp437, 69
698  br i1 %tmp477, label %bb478, label %bb433
699
700bb478:                                            ; preds = %bb475, %bb384
701  br label %bb479
702
703bb479:                                            ; preds = %bb479, %bb478
704  %tmp480 = phi i64 [ 0, %bb478 ], [ %tmp521, %bb479 ]
705  %tmp481 = phi i32 [ 0, %bb478 ], [ %tmp520, %bb479 ]
706  %tmp482 = and i64 %tmp480, 1
707  %tmp483 = icmp eq i64 %tmp482, 0
708  %tmp484 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp480
709  %tmp485 = load i32, i32* %tmp484, align 4
710  %tmp486 = sub i32 0, %tmp485
711  %tmp487 = select i1 %tmp483, i32 %tmp485, i32 %tmp486
712  %tmp488 = add i32 %tmp487, %tmp481
713  %tmp489 = add nuw nsw i64 %tmp480, 1
714  %tmp490 = and i64 %tmp489, 1
715  %tmp491 = icmp eq i64 %tmp490, 0
716  %tmp492 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp489
717  %tmp493 = load i32, i32* %tmp492, align 4
718  %tmp494 = sub i32 0, %tmp493
719  %tmp495 = select i1 %tmp491, i32 %tmp493, i32 %tmp494
720  %tmp496 = add i32 %tmp495, %tmp488
721  %tmp497 = add nuw nsw i64 %tmp480, 2
722  %tmp498 = and i64 %tmp497, 1
723  %tmp499 = icmp eq i64 %tmp498, 0
724  %tmp500 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp497
725  %tmp501 = load i32, i32* %tmp500, align 4
726  %tmp502 = sub i32 0, %tmp501
727  %tmp503 = select i1 %tmp499, i32 %tmp501, i32 %tmp502
728  %tmp504 = add i32 %tmp503, %tmp496
729  %tmp505 = add nuw nsw i64 %tmp480, 3
730  %tmp506 = and i64 %tmp505, 1
731  %tmp507 = icmp eq i64 %tmp506, 0
732  %tmp508 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp505
733  %tmp509 = load i32, i32* %tmp508, align 4
734  %tmp510 = sub i32 0, %tmp509
735  %tmp511 = select i1 %tmp507, i32 %tmp509, i32 %tmp510
736  %tmp512 = add i32 %tmp511, %tmp504
737  %tmp513 = add nuw nsw i64 %tmp480, 4
738  %tmp514 = and i64 %tmp513, 1
739  %tmp515 = icmp eq i64 %tmp514, 0
740  %tmp516 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp, i64 0, i64 %tmp513
741  %tmp517 = load i32, i32* %tmp516, align 4
742  %tmp518 = sub i32 0, %tmp517
743  %tmp519 = select i1 %tmp515, i32 %tmp517, i32 %tmp518
744  %tmp520 = add i32 %tmp519, %tmp512
745  %tmp521 = add nuw nsw i64 %tmp480, 5
746  %tmp522 = icmp eq i64 %tmp521, 100
747  br i1 %tmp522, label %bb523, label %bb479
748
749bb523:                                            ; preds = %bb523, %bb479
750  %tmp524 = phi i64 [ %tmp565, %bb523 ], [ 0, %bb479 ]
751  %tmp525 = phi i32 [ %tmp564, %bb523 ], [ 0, %bb479 ]
752  %tmp526 = and i64 %tmp524, 1
753  %tmp527 = icmp eq i64 %tmp526, 0
754  %tmp528 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp524
755  %tmp529 = load i32, i32* %tmp528, align 4
756  %tmp530 = sub i32 0, %tmp529
757  %tmp531 = select i1 %tmp527, i32 %tmp529, i32 %tmp530
758  %tmp532 = add i32 %tmp531, %tmp525
759  %tmp533 = add nuw nsw i64 %tmp524, 1
760  %tmp534 = and i64 %tmp533, 1
761  %tmp535 = icmp eq i64 %tmp534, 0
762  %tmp536 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp533
763  %tmp537 = load i32, i32* %tmp536, align 4
764  %tmp538 = sub i32 0, %tmp537
765  %tmp539 = select i1 %tmp535, i32 %tmp537, i32 %tmp538
766  %tmp540 = add i32 %tmp539, %tmp532
767  %tmp541 = add nuw nsw i64 %tmp524, 2
768  %tmp542 = and i64 %tmp541, 1
769  %tmp543 = icmp eq i64 %tmp542, 0
770  %tmp544 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp541
771  %tmp545 = load i32, i32* %tmp544, align 4
772  %tmp546 = sub i32 0, %tmp545
773  %tmp547 = select i1 %tmp543, i32 %tmp545, i32 %tmp546
774  %tmp548 = add i32 %tmp547, %tmp540
775  %tmp549 = add nuw nsw i64 %tmp524, 3
776  %tmp550 = and i64 %tmp549, 1
777  %tmp551 = icmp eq i64 %tmp550, 0
778  %tmp552 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp549
779  %tmp553 = load i32, i32* %tmp552, align 4
780  %tmp554 = sub i32 0, %tmp553
781  %tmp555 = select i1 %tmp551, i32 %tmp553, i32 %tmp554
782  %tmp556 = add i32 %tmp555, %tmp548
783  %tmp557 = add nuw nsw i64 %tmp524, 4
784  %tmp558 = and i64 %tmp557, 1
785  %tmp559 = icmp eq i64 %tmp558, 0
786  %tmp560 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp7, i64 0, i64 %tmp557
787  %tmp561 = load i32, i32* %tmp560, align 4
788  %tmp562 = sub i32 0, %tmp561
789  %tmp563 = select i1 %tmp559, i32 %tmp561, i32 %tmp562
790  %tmp564 = add i32 %tmp563, %tmp556
791  %tmp565 = add nuw nsw i64 %tmp524, 5
792  %tmp566 = icmp eq i64 %tmp565, 100
793  br i1 %tmp566, label %bb567, label %bb523
794
795bb567:                                            ; preds = %bb567, %bb523
796  %tmp568 = phi i64 [ %tmp609, %bb567 ], [ 0, %bb523 ]
797  %tmp569 = phi i32 [ %tmp608, %bb567 ], [ 0, %bb523 ]
798  %tmp570 = and i64 %tmp568, 1
799  %tmp571 = icmp eq i64 %tmp570, 0
800  %tmp572 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp568
801  %tmp573 = load i32, i32* %tmp572, align 4
802  %tmp574 = sub i32 0, %tmp573
803  %tmp575 = select i1 %tmp571, i32 %tmp573, i32 %tmp574
804  %tmp576 = add i32 %tmp575, %tmp569
805  %tmp577 = add nuw nsw i64 %tmp568, 1
806  %tmp578 = and i64 %tmp577, 1
807  %tmp579 = icmp eq i64 %tmp578, 0
808  %tmp580 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp577
809  %tmp581 = load i32, i32* %tmp580, align 4
810  %tmp582 = sub i32 0, %tmp581
811  %tmp583 = select i1 %tmp579, i32 %tmp581, i32 %tmp582
812  %tmp584 = add i32 %tmp583, %tmp576
813  %tmp585 = add nuw nsw i64 %tmp568, 2
814  %tmp586 = and i64 %tmp585, 1
815  %tmp587 = icmp eq i64 %tmp586, 0
816  %tmp588 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp585
817  %tmp589 = load i32, i32* %tmp588, align 4
818  %tmp590 = sub i32 0, %tmp589
819  %tmp591 = select i1 %tmp587, i32 %tmp589, i32 %tmp590
820  %tmp592 = add i32 %tmp591, %tmp584
821  %tmp593 = add nuw nsw i64 %tmp568, 3
822  %tmp594 = and i64 %tmp593, 1
823  %tmp595 = icmp eq i64 %tmp594, 0
824  %tmp596 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp593
825  %tmp597 = load i32, i32* %tmp596, align 4
826  %tmp598 = sub i32 0, %tmp597
827  %tmp599 = select i1 %tmp595, i32 %tmp597, i32 %tmp598
828  %tmp600 = add i32 %tmp599, %tmp592
829  %tmp601 = add nuw nsw i64 %tmp568, 4
830  %tmp602 = and i64 %tmp601, 1
831  %tmp603 = icmp eq i64 %tmp602, 0
832  %tmp604 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp8, i64 0, i64 %tmp601
833  %tmp605 = load i32, i32* %tmp604, align 4
834  %tmp606 = sub i32 0, %tmp605
835  %tmp607 = select i1 %tmp603, i32 %tmp605, i32 %tmp606
836  %tmp608 = add i32 %tmp607, %tmp600
837  %tmp609 = add nuw nsw i64 %tmp568, 5
838  %tmp610 = icmp eq i64 %tmp609, 100
839  br i1 %tmp610, label %bb611, label %bb567
840
841bb611:                                            ; preds = %bb611, %bb567
842  %tmp612 = phi i64 [ %tmp653, %bb611 ], [ 0, %bb567 ]
843  %tmp613 = phi i32 [ %tmp652, %bb611 ], [ 0, %bb567 ]
844  %tmp614 = and i64 %tmp612, 1
845  %tmp615 = icmp eq i64 %tmp614, 0
846  %tmp616 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp612
847  %tmp617 = load i32, i32* %tmp616, align 4
848  %tmp618 = sub i32 0, %tmp617
849  %tmp619 = select i1 %tmp615, i32 %tmp617, i32 %tmp618
850  %tmp620 = add i32 %tmp619, %tmp613
851  %tmp621 = add nuw nsw i64 %tmp612, 1
852  %tmp622 = and i64 %tmp621, 1
853  %tmp623 = icmp eq i64 %tmp622, 0
854  %tmp624 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp621
855  %tmp625 = load i32, i32* %tmp624, align 4
856  %tmp626 = sub i32 0, %tmp625
857  %tmp627 = select i1 %tmp623, i32 %tmp625, i32 %tmp626
858  %tmp628 = add i32 %tmp627, %tmp620
859  %tmp629 = add nuw nsw i64 %tmp612, 2
860  %tmp630 = and i64 %tmp629, 1
861  %tmp631 = icmp eq i64 %tmp630, 0
862  %tmp632 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp629
863  %tmp633 = load i32, i32* %tmp632, align 4
864  %tmp634 = sub i32 0, %tmp633
865  %tmp635 = select i1 %tmp631, i32 %tmp633, i32 %tmp634
866  %tmp636 = add i32 %tmp635, %tmp628
867  %tmp637 = add nuw nsw i64 %tmp612, 3
868  %tmp638 = and i64 %tmp637, 1
869  %tmp639 = icmp eq i64 %tmp638, 0
870  %tmp640 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp637
871  %tmp641 = load i32, i32* %tmp640, align 4
872  %tmp642 = sub i32 0, %tmp641
873  %tmp643 = select i1 %tmp639, i32 %tmp641, i32 %tmp642
874  %tmp644 = add i32 %tmp643, %tmp636
875  %tmp645 = add nuw nsw i64 %tmp612, 4
876  %tmp646 = and i64 %tmp645, 1
877  %tmp647 = icmp eq i64 %tmp646, 0
878  %tmp648 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp9, i64 0, i64 0, i64 %tmp645
879  %tmp649 = load i32, i32* %tmp648, align 4
880  %tmp650 = sub i32 0, %tmp649
881  %tmp651 = select i1 %tmp647, i32 %tmp649, i32 %tmp650
882  %tmp652 = add i32 %tmp651, %tmp644
883  %tmp653 = add nuw nsw i64 %tmp612, 5
884  %tmp654 = icmp eq i64 %tmp653, 10000
885  br i1 %tmp654, label %bb655, label %bb611
886
887bb655:                                            ; preds = %bb655, %bb611
888  %tmp656 = phi i64 [ %tmp697, %bb655 ], [ 0, %bb611 ]
889  %tmp657 = phi i32 [ %tmp696, %bb655 ], [ 0, %bb611 ]
890  %tmp658 = and i64 %tmp656, 1
891  %tmp659 = icmp eq i64 %tmp658, 0
892  %tmp660 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp656
893  %tmp661 = load i32, i32* %tmp660, align 4
894  %tmp662 = sub i32 0, %tmp661
895  %tmp663 = select i1 %tmp659, i32 %tmp661, i32 %tmp662
896  %tmp664 = add i32 %tmp663, %tmp657
897  %tmp665 = add nuw nsw i64 %tmp656, 1
898  %tmp666 = and i64 %tmp665, 1
899  %tmp667 = icmp eq i64 %tmp666, 0
900  %tmp668 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp665
901  %tmp669 = load i32, i32* %tmp668, align 4
902  %tmp670 = sub i32 0, %tmp669
903  %tmp671 = select i1 %tmp667, i32 %tmp669, i32 %tmp670
904  %tmp672 = add i32 %tmp671, %tmp664
905  %tmp673 = add nuw nsw i64 %tmp656, 2
906  %tmp674 = and i64 %tmp673, 1
907  %tmp675 = icmp eq i64 %tmp674, 0
908  %tmp676 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp673
909  %tmp677 = load i32, i32* %tmp676, align 4
910  %tmp678 = sub i32 0, %tmp677
911  %tmp679 = select i1 %tmp675, i32 %tmp677, i32 %tmp678
912  %tmp680 = add i32 %tmp679, %tmp672
913  %tmp681 = add nuw nsw i64 %tmp656, 3
914  %tmp682 = and i64 %tmp681, 1
915  %tmp683 = icmp eq i64 %tmp682, 0
916  %tmp684 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp681
917  %tmp685 = load i32, i32* %tmp684, align 4
918  %tmp686 = sub i32 0, %tmp685
919  %tmp687 = select i1 %tmp683, i32 %tmp685, i32 %tmp686
920  %tmp688 = add i32 %tmp687, %tmp680
921  %tmp689 = add nuw nsw i64 %tmp656, 4
922  %tmp690 = and i64 %tmp689, 1
923  %tmp691 = icmp eq i64 %tmp690, 0
924  %tmp692 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp10, i64 0, i64 %tmp689
925  %tmp693 = load i32, i32* %tmp692, align 4
926  %tmp694 = sub i32 0, %tmp693
927  %tmp695 = select i1 %tmp691, i32 %tmp693, i32 %tmp694
928  %tmp696 = add i32 %tmp695, %tmp688
929  %tmp697 = add nuw nsw i64 %tmp656, 5
930  %tmp698 = icmp eq i64 %tmp697, 100
931  br i1 %tmp698, label %bb699, label %bb655
932
933bb699:                                            ; preds = %bb699, %bb655
934  %tmp700 = phi i64 [ %tmp741, %bb699 ], [ 0, %bb655 ]
935  %tmp701 = phi i32 [ %tmp740, %bb699 ], [ 0, %bb655 ]
936  %tmp702 = and i64 %tmp700, 1
937  %tmp703 = icmp eq i64 %tmp702, 0
938  %tmp704 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp700
939  %tmp705 = load i32, i32* %tmp704, align 4
940  %tmp706 = sub i32 0, %tmp705
941  %tmp707 = select i1 %tmp703, i32 %tmp705, i32 %tmp706
942  %tmp708 = add i32 %tmp707, %tmp701
943  %tmp709 = add nuw nsw i64 %tmp700, 1
944  %tmp710 = and i64 %tmp709, 1
945  %tmp711 = icmp eq i64 %tmp710, 0
946  %tmp712 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp709
947  %tmp713 = load i32, i32* %tmp712, align 4
948  %tmp714 = sub i32 0, %tmp713
949  %tmp715 = select i1 %tmp711, i32 %tmp713, i32 %tmp714
950  %tmp716 = add i32 %tmp715, %tmp708
951  %tmp717 = add nuw nsw i64 %tmp700, 2
952  %tmp718 = and i64 %tmp717, 1
953  %tmp719 = icmp eq i64 %tmp718, 0
954  %tmp720 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp717
955  %tmp721 = load i32, i32* %tmp720, align 4
956  %tmp722 = sub i32 0, %tmp721
957  %tmp723 = select i1 %tmp719, i32 %tmp721, i32 %tmp722
958  %tmp724 = add i32 %tmp723, %tmp716
959  %tmp725 = add nuw nsw i64 %tmp700, 3
960  %tmp726 = and i64 %tmp725, 1
961  %tmp727 = icmp eq i64 %tmp726, 0
962  %tmp728 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp725
963  %tmp729 = load i32, i32* %tmp728, align 4
964  %tmp730 = sub i32 0, %tmp729
965  %tmp731 = select i1 %tmp727, i32 %tmp729, i32 %tmp730
966  %tmp732 = add i32 %tmp731, %tmp724
967  %tmp733 = add nuw nsw i64 %tmp700, 4
968  %tmp734 = and i64 %tmp733, 1
969  %tmp735 = icmp eq i64 %tmp734, 0
970  %tmp736 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp11, i64 0, i64 0, i64 %tmp733
971  %tmp737 = load i32, i32* %tmp736, align 4
972  %tmp738 = sub i32 0, %tmp737
973  %tmp739 = select i1 %tmp735, i32 %tmp737, i32 %tmp738
974  %tmp740 = add i32 %tmp739, %tmp732
975  %tmp741 = add nuw nsw i64 %tmp700, 5
976  %tmp742 = icmp eq i64 %tmp741, 10000
977  br i1 %tmp742, label %bb743, label %bb699
978
979bb743:                                            ; preds = %bb743, %bb699
980  %tmp744 = phi i64 [ %tmp785, %bb743 ], [ 0, %bb699 ]
981  %tmp745 = phi i32 [ %tmp784, %bb743 ], [ 0, %bb699 ]
982  %tmp746 = and i64 %tmp744, 1
983  %tmp747 = icmp eq i64 %tmp746, 0
984  %tmp748 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp744
985  %tmp749 = load i32, i32* %tmp748, align 4
986  %tmp750 = sub i32 0, %tmp749
987  %tmp751 = select i1 %tmp747, i32 %tmp749, i32 %tmp750
988  %tmp752 = add i32 %tmp751, %tmp745
989  %tmp753 = add nuw nsw i64 %tmp744, 1
990  %tmp754 = and i64 %tmp753, 1
991  %tmp755 = icmp eq i64 %tmp754, 0
992  %tmp756 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp753
993  %tmp757 = load i32, i32* %tmp756, align 4
994  %tmp758 = sub i32 0, %tmp757
995  %tmp759 = select i1 %tmp755, i32 %tmp757, i32 %tmp758
996  %tmp760 = add i32 %tmp759, %tmp752
997  %tmp761 = add nuw nsw i64 %tmp744, 2
998  %tmp762 = and i64 %tmp761, 1
999  %tmp763 = icmp eq i64 %tmp762, 0
1000  %tmp764 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp761
1001  %tmp765 = load i32, i32* %tmp764, align 4
1002  %tmp766 = sub i32 0, %tmp765
1003  %tmp767 = select i1 %tmp763, i32 %tmp765, i32 %tmp766
1004  %tmp768 = add i32 %tmp767, %tmp760
1005  %tmp769 = add nuw nsw i64 %tmp744, 3
1006  %tmp770 = and i64 %tmp769, 1
1007  %tmp771 = icmp eq i64 %tmp770, 0
1008  %tmp772 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp769
1009  %tmp773 = load i32, i32* %tmp772, align 4
1010  %tmp774 = sub i32 0, %tmp773
1011  %tmp775 = select i1 %tmp771, i32 %tmp773, i32 %tmp774
1012  %tmp776 = add i32 %tmp775, %tmp768
1013  %tmp777 = add nuw nsw i64 %tmp744, 4
1014  %tmp778 = and i64 %tmp777, 1
1015  %tmp779 = icmp eq i64 %tmp778, 0
1016  %tmp780 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp12, i64 0, i64 %tmp777
1017  %tmp781 = load i32, i32* %tmp780, align 4
1018  %tmp782 = sub i32 0, %tmp781
1019  %tmp783 = select i1 %tmp779, i32 %tmp781, i32 %tmp782
1020  %tmp784 = add i32 %tmp783, %tmp776
1021  %tmp785 = add nuw nsw i64 %tmp744, 5
1022  %tmp786 = icmp eq i64 %tmp785, 100
1023  br i1 %tmp786, label %bb787, label %bb743
1024
1025bb787:                                            ; preds = %bb787, %bb743
1026  %tmp788 = phi i64 [ %tmp829, %bb787 ], [ 0, %bb743 ]
1027  %tmp789 = phi i32 [ %tmp828, %bb787 ], [ 0, %bb743 ]
1028  %tmp790 = and i64 %tmp788, 1
1029  %tmp791 = icmp eq i64 %tmp790, 0
1030  %tmp792 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp788
1031  %tmp793 = load i32, i32* %tmp792, align 4
1032  %tmp794 = sub i32 0, %tmp793
1033  %tmp795 = select i1 %tmp791, i32 %tmp793, i32 %tmp794
1034  %tmp796 = add i32 %tmp795, %tmp789
1035  %tmp797 = add nuw nsw i64 %tmp788, 1
1036  %tmp798 = and i64 %tmp797, 1
1037  %tmp799 = icmp eq i64 %tmp798, 0
1038  %tmp800 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp797
1039  %tmp801 = load i32, i32* %tmp800, align 4
1040  %tmp802 = sub i32 0, %tmp801
1041  %tmp803 = select i1 %tmp799, i32 %tmp801, i32 %tmp802
1042  %tmp804 = add i32 %tmp803, %tmp796
1043  %tmp805 = add nuw nsw i64 %tmp788, 2
1044  %tmp806 = and i64 %tmp805, 1
1045  %tmp807 = icmp eq i64 %tmp806, 0
1046  %tmp808 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp805
1047  %tmp809 = load i32, i32* %tmp808, align 4
1048  %tmp810 = sub i32 0, %tmp809
1049  %tmp811 = select i1 %tmp807, i32 %tmp809, i32 %tmp810
1050  %tmp812 = add i32 %tmp811, %tmp804
1051  %tmp813 = add nuw nsw i64 %tmp788, 3
1052  %tmp814 = and i64 %tmp813, 1
1053  %tmp815 = icmp eq i64 %tmp814, 0
1054  %tmp816 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp813
1055  %tmp817 = load i32, i32* %tmp816, align 4
1056  %tmp818 = sub i32 0, %tmp817
1057  %tmp819 = select i1 %tmp815, i32 %tmp817, i32 %tmp818
1058  %tmp820 = add i32 %tmp819, %tmp812
1059  %tmp821 = add nuw nsw i64 %tmp788, 4
1060  %tmp822 = and i64 %tmp821, 1
1061  %tmp823 = icmp eq i64 %tmp822, 0
1062  %tmp824 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp13, i64 0, i64 %tmp821
1063  %tmp825 = load i32, i32* %tmp824, align 4
1064  %tmp826 = sub i32 0, %tmp825
1065  %tmp827 = select i1 %tmp823, i32 %tmp825, i32 %tmp826
1066  %tmp828 = add i32 %tmp827, %tmp820
1067  %tmp829 = add nuw nsw i64 %tmp788, 5
1068  %tmp830 = icmp eq i64 %tmp829, 100
1069  br i1 %tmp830, label %bb831, label %bb787
1070
1071bb831:                                            ; preds = %bb831, %bb787
1072  %tmp832 = phi i64 [ %tmp873, %bb831 ], [ 0, %bb787 ]
1073  %tmp833 = phi i32 [ %tmp872, %bb831 ], [ 0, %bb787 ]
1074  %tmp834 = and i64 %tmp832, 1
1075  %tmp835 = icmp eq i64 %tmp834, 0
1076  %tmp836 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp832
1077  %tmp837 = load i32, i32* %tmp836, align 4
1078  %tmp838 = sub i32 0, %tmp837
1079  %tmp839 = select i1 %tmp835, i32 %tmp837, i32 %tmp838
1080  %tmp840 = add i32 %tmp839, %tmp833
1081  %tmp841 = add nuw nsw i64 %tmp832, 1
1082  %tmp842 = and i64 %tmp841, 1
1083  %tmp843 = icmp eq i64 %tmp842, 0
1084  %tmp844 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp841
1085  %tmp845 = load i32, i32* %tmp844, align 4
1086  %tmp846 = sub i32 0, %tmp845
1087  %tmp847 = select i1 %tmp843, i32 %tmp845, i32 %tmp846
1088  %tmp848 = add i32 %tmp847, %tmp840
1089  %tmp849 = add nuw nsw i64 %tmp832, 2
1090  %tmp850 = and i64 %tmp849, 1
1091  %tmp851 = icmp eq i64 %tmp850, 0
1092  %tmp852 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp849
1093  %tmp853 = load i32, i32* %tmp852, align 4
1094  %tmp854 = sub i32 0, %tmp853
1095  %tmp855 = select i1 %tmp851, i32 %tmp853, i32 %tmp854
1096  %tmp856 = add i32 %tmp855, %tmp848
1097  %tmp857 = add nuw nsw i64 %tmp832, 3
1098  %tmp858 = and i64 %tmp857, 1
1099  %tmp859 = icmp eq i64 %tmp858, 0
1100  %tmp860 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp857
1101  %tmp861 = load i32, i32* %tmp860, align 4
1102  %tmp862 = sub i32 0, %tmp861
1103  %tmp863 = select i1 %tmp859, i32 %tmp861, i32 %tmp862
1104  %tmp864 = add i32 %tmp863, %tmp856
1105  %tmp865 = add nuw nsw i64 %tmp832, 4
1106  %tmp866 = and i64 %tmp865, 1
1107  %tmp867 = icmp eq i64 %tmp866, 0
1108  %tmp868 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp14, i64 0, i64 0, i64 %tmp865
1109  %tmp869 = load i32, i32* %tmp868, align 4
1110  %tmp870 = sub i32 0, %tmp869
1111  %tmp871 = select i1 %tmp867, i32 %tmp869, i32 %tmp870
1112  %tmp872 = add i32 %tmp871, %tmp864
1113  %tmp873 = add nuw nsw i64 %tmp832, 5
1114  %tmp874 = icmp eq i64 %tmp873, 10000
1115  br i1 %tmp874, label %bb875, label %bb831
1116
1117bb875:                                            ; preds = %bb875, %bb831
1118  %tmp876 = phi i64 [ %tmp917, %bb875 ], [ 0, %bb831 ]
1119  %tmp877 = phi i32 [ %tmp916, %bb875 ], [ 0, %bb831 ]
1120  %tmp878 = and i64 %tmp876, 1
1121  %tmp879 = icmp eq i64 %tmp878, 0
1122  %tmp880 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp876
1123  %tmp881 = load i32, i32* %tmp880, align 4
1124  %tmp882 = sub i32 0, %tmp881
1125  %tmp883 = select i1 %tmp879, i32 %tmp881, i32 %tmp882
1126  %tmp884 = add i32 %tmp883, %tmp877
1127  %tmp885 = add nuw nsw i64 %tmp876, 1
1128  %tmp886 = and i64 %tmp885, 1
1129  %tmp887 = icmp eq i64 %tmp886, 0
1130  %tmp888 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp885
1131  %tmp889 = load i32, i32* %tmp888, align 4
1132  %tmp890 = sub i32 0, %tmp889
1133  %tmp891 = select i1 %tmp887, i32 %tmp889, i32 %tmp890
1134  %tmp892 = add i32 %tmp891, %tmp884
1135  %tmp893 = add nuw nsw i64 %tmp876, 2
1136  %tmp894 = and i64 %tmp893, 1
1137  %tmp895 = icmp eq i64 %tmp894, 0
1138  %tmp896 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp893
1139  %tmp897 = load i32, i32* %tmp896, align 4
1140  %tmp898 = sub i32 0, %tmp897
1141  %tmp899 = select i1 %tmp895, i32 %tmp897, i32 %tmp898
1142  %tmp900 = add i32 %tmp899, %tmp892
1143  %tmp901 = add nuw nsw i64 %tmp876, 3
1144  %tmp902 = and i64 %tmp901, 1
1145  %tmp903 = icmp eq i64 %tmp902, 0
1146  %tmp904 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp901
1147  %tmp905 = load i32, i32* %tmp904, align 4
1148  %tmp906 = sub i32 0, %tmp905
1149  %tmp907 = select i1 %tmp903, i32 %tmp905, i32 %tmp906
1150  %tmp908 = add i32 %tmp907, %tmp900
1151  %tmp909 = add nuw nsw i64 %tmp876, 4
1152  %tmp910 = and i64 %tmp909, 1
1153  %tmp911 = icmp eq i64 %tmp910, 0
1154  %tmp912 = getelementptr inbounds [100 x i32], [100 x i32]* %tmp15, i64 0, i64 %tmp909
1155  %tmp913 = load i32, i32* %tmp912, align 4
1156  %tmp914 = sub i32 0, %tmp913
1157  %tmp915 = select i1 %tmp911, i32 %tmp913, i32 %tmp914
1158  %tmp916 = add i32 %tmp915, %tmp908
1159  %tmp917 = add nuw nsw i64 %tmp876, 5
1160  %tmp918 = icmp eq i64 %tmp917, 100
1161  br i1 %tmp918, label %bb919, label %bb875
1162
1163bb919:                                            ; preds = %bb919, %bb875
1164  %tmp920 = phi i64 [ %tmp961, %bb919 ], [ 0, %bb875 ]
1165  %tmp921 = phi i32 [ %tmp960, %bb919 ], [ 0, %bb875 ]
1166  %tmp922 = and i64 %tmp920, 1
1167  %tmp923 = icmp eq i64 %tmp922, 0
1168  %tmp924 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp920
1169  %tmp925 = load i32, i32* %tmp924, align 4
1170  %tmp926 = sub i32 0, %tmp925
1171  %tmp927 = select i1 %tmp923, i32 %tmp925, i32 %tmp926
1172  %tmp928 = add i32 %tmp927, %tmp921
1173  %tmp929 = add nuw nsw i64 %tmp920, 1
1174  %tmp930 = and i64 %tmp929, 1
1175  %tmp931 = icmp eq i64 %tmp930, 0
1176  %tmp932 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp929
1177  %tmp933 = load i32, i32* %tmp932, align 4
1178  %tmp934 = sub i32 0, %tmp933
1179  %tmp935 = select i1 %tmp931, i32 %tmp933, i32 %tmp934
1180  %tmp936 = add i32 %tmp935, %tmp928
1181  %tmp937 = add nuw nsw i64 %tmp920, 2
1182  %tmp938 = and i64 %tmp937, 1
1183  %tmp939 = icmp eq i64 %tmp938, 0
1184  %tmp940 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp937
1185  %tmp941 = load i32, i32* %tmp940, align 4
1186  %tmp942 = sub i32 0, %tmp941
1187  %tmp943 = select i1 %tmp939, i32 %tmp941, i32 %tmp942
1188  %tmp944 = add i32 %tmp943, %tmp936
1189  %tmp945 = add nuw nsw i64 %tmp920, 3
1190  %tmp946 = and i64 %tmp945, 1
1191  %tmp947 = icmp eq i64 %tmp946, 0
1192  %tmp948 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp945
1193  %tmp949 = load i32, i32* %tmp948, align 4
1194  %tmp950 = sub i32 0, %tmp949
1195  %tmp951 = select i1 %tmp947, i32 %tmp949, i32 %tmp950
1196  %tmp952 = add i32 %tmp951, %tmp944
1197  %tmp953 = add nuw nsw i64 %tmp920, 4
1198  %tmp954 = and i64 %tmp953, 1
1199  %tmp955 = icmp eq i64 %tmp954, 0
1200  %tmp956 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp16, i64 0, i64 0, i64 %tmp953
1201  %tmp957 = load i32, i32* %tmp956, align 4
1202  %tmp958 = sub i32 0, %tmp957
1203  %tmp959 = select i1 %tmp955, i32 %tmp957, i32 %tmp958
1204  %tmp960 = add i32 %tmp959, %tmp952
1205  %tmp961 = add nuw nsw i64 %tmp920, 5
1206  %tmp962 = icmp eq i64 %tmp961, 10000
1207  br i1 %tmp962, label %bb963, label %bb919
1208
1209bb963:                                            ; preds = %bb963, %bb919
1210  %tmp964 = phi i64 [ %tmp1005, %bb963 ], [ 0, %bb919 ]
1211  %tmp965 = phi i32 [ %tmp1004, %bb963 ], [ 0, %bb919 ]
1212  %tmp966 = and i64 %tmp964, 1
1213  %tmp967 = icmp eq i64 %tmp966, 0
1214  %tmp968 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp964
1215  %tmp969 = load i32, i32* %tmp968, align 4
1216  %tmp970 = sub i32 0, %tmp969
1217  %tmp971 = select i1 %tmp967, i32 %tmp969, i32 %tmp970
1218  %tmp972 = add i32 %tmp971, %tmp965
1219  %tmp973 = add nuw nsw i64 %tmp964, 1
1220  %tmp974 = and i64 %tmp973, 1
1221  %tmp975 = icmp eq i64 %tmp974, 0
1222  %tmp976 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp973
1223  %tmp977 = load i32, i32* %tmp976, align 4
1224  %tmp978 = sub i32 0, %tmp977
1225  %tmp979 = select i1 %tmp975, i32 %tmp977, i32 %tmp978
1226  %tmp980 = add i32 %tmp979, %tmp972
1227  %tmp981 = add nuw nsw i64 %tmp964, 2
1228  %tmp982 = and i64 %tmp981, 1
1229  %tmp983 = icmp eq i64 %tmp982, 0
1230  %tmp984 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp981
1231  %tmp985 = load i32, i32* %tmp984, align 4
1232  %tmp986 = sub i32 0, %tmp985
1233  %tmp987 = select i1 %tmp983, i32 %tmp985, i32 %tmp986
1234  %tmp988 = add i32 %tmp987, %tmp980
1235  %tmp989 = add nuw nsw i64 %tmp964, 3
1236  %tmp990 = and i64 %tmp989, 1
1237  %tmp991 = icmp eq i64 %tmp990, 0
1238  %tmp992 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp989
1239  %tmp993 = load i32, i32* %tmp992, align 4
1240  %tmp994 = sub i32 0, %tmp993
1241  %tmp995 = select i1 %tmp991, i32 %tmp993, i32 %tmp994
1242  %tmp996 = add i32 %tmp995, %tmp988
1243  %tmp997 = add nuw nsw i64 %tmp964, 4
1244  %tmp998 = and i64 %tmp997, 1
1245  %tmp999 = icmp eq i64 %tmp998, 0
1246  %tmp1000 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp17, i64 0, i64 0, i64 %tmp997
1247  %tmp1001 = load i32, i32* %tmp1000, align 4
1248  %tmp1002 = sub i32 0, %tmp1001
1249  %tmp1003 = select i1 %tmp999, i32 %tmp1001, i32 %tmp1002
1250  %tmp1004 = add i32 %tmp1003, %tmp996
1251  %tmp1005 = add nuw nsw i64 %tmp964, 5
1252  %tmp1006 = icmp eq i64 %tmp1005, 10000
1253  br i1 %tmp1006, label %bb1007, label %bb963
1254
1255bb1007:                                           ; preds = %bb1007, %bb963
1256  %tmp1008 = phi i64 [ %tmp1049, %bb1007 ], [ 0, %bb963 ]
1257  %tmp1009 = phi i32 [ %tmp1048, %bb1007 ], [ 0, %bb963 ]
1258  %tmp1010 = and i64 %tmp1008, 1
1259  %tmp1011 = icmp eq i64 %tmp1010, 0
1260  %tmp1012 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp1008
1261  %tmp1013 = load i32, i32* %tmp1012, align 4
1262  %tmp1014 = sub i32 0, %tmp1013
1263  %tmp1015 = select i1 %tmp1011, i32 %tmp1013, i32 %tmp1014
1264  %tmp1016 = add i32 %tmp1015, %tmp1009
1265  %tmp1017 = add nuw nsw i64 %tmp1008, 1
1266  %tmp1018 = and i64 %tmp1017, 1
1267  %tmp1019 = icmp eq i64 %tmp1018, 0
1268  %tmp1020 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp1017
1269  %tmp1021 = load i32, i32* %tmp1020, align 4
1270  %tmp1022 = sub i32 0, %tmp1021
1271  %tmp1023 = select i1 %tmp1019, i32 %tmp1021, i32 %tmp1022
1272  %tmp1024 = add i32 %tmp1023, %tmp1016
1273  %tmp1025 = add nuw nsw i64 %tmp1008, 2
1274  %tmp1026 = and i64 %tmp1025, 1
1275  %tmp1027 = icmp eq i64 %tmp1026, 0
1276  %tmp1028 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp1025
1277  %tmp1029 = load i32, i32* %tmp1028, align 4
1278  %tmp1030 = sub i32 0, %tmp1029
1279  %tmp1031 = select i1 %tmp1027, i32 %tmp1029, i32 %tmp1030
1280  %tmp1032 = add i32 %tmp1031, %tmp1024
1281  %tmp1033 = add nuw nsw i64 %tmp1008, 3
1282  %tmp1034 = and i64 %tmp1033, 1
1283  %tmp1035 = icmp eq i64 %tmp1034, 0
1284  %tmp1036 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp1033
1285  %tmp1037 = load i32, i32* %tmp1036, align 4
1286  %tmp1038 = sub i32 0, %tmp1037
1287  %tmp1039 = select i1 %tmp1035, i32 %tmp1037, i32 %tmp1038
1288  %tmp1040 = add i32 %tmp1039, %tmp1032
1289  %tmp1041 = add nuw nsw i64 %tmp1008, 4
1290  %tmp1042 = and i64 %tmp1041, 1
1291  %tmp1043 = icmp eq i64 %tmp1042, 0
1292  %tmp1044 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* %tmp18, i64 0, i64 0, i64 %tmp1041
1293  %tmp1045 = load i32, i32* %tmp1044, align 4
1294  %tmp1046 = sub i32 0, %tmp1045
1295  %tmp1047 = select i1 %tmp1043, i32 %tmp1045, i32 %tmp1046
1296  %tmp1048 = add i32 %tmp1047, %tmp1040
1297  %tmp1049 = add nuw nsw i64 %tmp1008, 5
1298  %tmp1050 = icmp eq i64 %tmp1049, 10000
1299  br i1 %tmp1050, label %bb1051, label %bb1007
1300
1301bb1051:                                           ; preds = %bb1007
1302  %tmp1052 = add i32 %tmp382, %tmp385
1303  %tmp1053 = add i32 %tmp1052, %tmp520
1304  %tmp1054 = add i32 %tmp1053, %tmp564
1305  %tmp1055 = sub i32 %tmp1054, %tmp608
1306  %tmp1056 = add i32 %tmp1055, %tmp652
1307  %tmp1057 = sub i32 %tmp1056, %tmp696
1308  %tmp1058 = add i32 %tmp1057, %tmp740
1309  %tmp1059 = sub i32 %tmp1058, %tmp784
1310  %tmp1060 = add i32 %tmp1059, %tmp828
1311  %tmp1061 = sub i32 %tmp1060, %tmp872
1312  %tmp1062 = add i32 %tmp1061, %tmp916
1313  %tmp1063 = sub i32 %tmp1062, %tmp960
1314  %tmp1064 = add i32 %tmp1063, %tmp1004
1315  %tmp1065 = sub i32 %tmp1064, %tmp1048
1316  call void @llvm.lifetime.end.p0i8(i64 40000, i8* nonnull %tmp31) #4
1317  call void @llvm.lifetime.end.p0i8(i64 40000, i8* nonnull %tmp30) #4
1318  call void @llvm.lifetime.end.p0i8(i64 40000, i8* nonnull %tmp29) #4
1319  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp28) #4
1320  call void @llvm.lifetime.end.p0i8(i64 40000, i8* nonnull %tmp27) #4
1321  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp26) #4
1322  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp25) #4
1323  call void @llvm.lifetime.end.p0i8(i64 40000, i8* nonnull %tmp24) #4
1324  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp23) #4
1325  call void @llvm.lifetime.end.p0i8(i64 40000, i8* nonnull %tmp22) #4
1326  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp21) #4
1327  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp20) #4
1328  call void @llvm.lifetime.end.p0i8(i64 400, i8* nonnull %tmp19) #4
1329  ret i32 %tmp1065
1330}
1331
1332; Function Attrs: argmemonly nounwind
1333declare void @llvm.memset.p0i8.i64(i8* nocapture writeonly, i8, i64, i1) #1
1334
1335; Function Attrs: argmemonly nounwind
1336declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture writeonly, i8* nocapture readonly, i64, i1) #1
1337