[InstCombine] Signed saturation patterns
[llvm-core.git] / test / Transforms / LoopUnroll / 2007-11-05-Crash.ll
blob1711f11999743d292b377bd2247dc938fc010aee
1 ; RUN: opt < %s -disable-output -loop-unroll
2 ; PR1770
3 ; PR1947
5         %struct.cl_engine = type { i32, i16, i32, i8**, i8**, i8*, i8*, i8*, i8*, i8*, i8*, i8* }
6         %struct.cl_limits = type { i32, i32, i32, i32, i16, i64 }
7         %struct.cli_ac_alt = type { i8, i8*, i16, i16, %struct.cli_ac_alt* }
8         %struct.cli_ac_node = type { i8, i8, %struct.cli_ac_patt*, %struct.cli_ac_node**, %struct.cli_ac_node* }
9         %struct.cli_ac_patt = type { i16*, i16*, i16, i16, i8, i32, i32, i8*, i8*, i32, i16, i16, i16, i16, %struct.cli_ac_alt**, i8, i16, %struct.cli_ac_patt*, %struct.cli_ac_patt* }
10         %struct.cli_bm_patt = type { i8*, i32, i8*, i8*, i8, %struct.cli_bm_patt* }
11         %struct.cli_ctx = type { i8**, i64*, %struct.cli_matcher*, %struct.cl_engine*, %struct.cl_limits*, i32, i32, i32, i32, %struct.cli_dconf* }
12         %struct.cli_dconf = type { i32, i32, i32, i32, i32, i32, i32 }
13         %struct.cli_matcher = type { i16, i8, i32*, %struct.cli_bm_patt**, i32*, i32, i8, i8, %struct.cli_ac_node*, %struct.cli_ac_node**, %struct.cli_ac_patt**, i32, i32, i32 }
15 declare i8* @calloc(i64, i64)
17 define fastcc i32 @cli_scanpe(i32 %desc, %struct.cli_ctx* %ctx) {
18 entry:
19         br i1 false, label %cond_next17, label %cond_true14
21 cond_true14:            ; preds = %entry
22         ret i32 0
24 cond_next17:            ; preds = %entry
25         br i1 false, label %LeafBlock, label %LeafBlock1250
27 LeafBlock1250:          ; preds = %cond_next17
28         ret i32 0
30 LeafBlock:              ; preds = %cond_next17
31         br i1 false, label %cond_next33, label %cond_true30
33 cond_true30:            ; preds = %LeafBlock
34         ret i32 0
36 cond_next33:            ; preds = %LeafBlock
37         br i1 false, label %cond_next90, label %cond_true42
39 cond_true42:            ; preds = %cond_next33
40         ret i32 0
42 cond_next90:            ; preds = %cond_next33
43         br i1 false, label %cond_next100, label %cond_true97
45 cond_true97:            ; preds = %cond_next90
46         ret i32 0
48 cond_next100:           ; preds = %cond_next90
49         br i1 false, label %cond_next109, label %cond_true106
51 cond_true106:           ; preds = %cond_next100
52         ret i32 0
54 cond_next109:           ; preds = %cond_next100
55         br i1 false, label %cond_false, label %cond_true118
57 cond_true118:           ; preds = %cond_next109
58         ret i32 0
60 cond_false:             ; preds = %cond_next109
61         br i1 false, label %NodeBlock1482, label %cond_true126
63 cond_true126:           ; preds = %cond_false
64         ret i32 0
66 NodeBlock1482:          ; preds = %cond_false
67         br i1 false, label %cond_next285, label %NodeBlock1480
69 NodeBlock1480:          ; preds = %NodeBlock1482
70         ret i32 0
72 cond_next285:           ; preds = %NodeBlock1482
73         br i1 false, label %cond_next320, label %cond_true294
75 cond_true294:           ; preds = %cond_next285
76         ret i32 0
78 cond_next320:           ; preds = %cond_next285
79         br i1 false, label %LeafBlock1491, label %LeafBlock1493
81 LeafBlock1493:          ; preds = %cond_next320
82         ret i32 0
84 LeafBlock1491:          ; preds = %cond_next320
85         br i1 false, label %cond_true400, label %cond_true378
87 cond_true378:           ; preds = %LeafBlock1491
88         ret i32 1
90 cond_true400:           ; preds = %LeafBlock1491
91         br i1 false, label %cond_next413, label %cond_true406
93 cond_true406:           ; preds = %cond_true400
94         ret i32 0
96 cond_next413:           ; preds = %cond_true400
97         br i1 false, label %cond_next429, label %cond_true424
99 cond_true424:           ; preds = %cond_next413
100         ret i32 0
102 cond_next429:           ; preds = %cond_next413
103         br i1 false, label %NodeBlock1557, label %NodeBlock1579
105 NodeBlock1579:          ; preds = %cond_next429
106         ret i32 0
108 NodeBlock1557:          ; preds = %cond_next429
109         br i1 false, label %LeafBlock1543, label %NodeBlock1555
111 NodeBlock1555:          ; preds = %NodeBlock1557
112         ret i32 0
114 LeafBlock1543:          ; preds = %NodeBlock1557
115         br i1 false, label %cond_next870, label %cond_next663
117 cond_next663:           ; preds = %LeafBlock1543
118         ret i32 0
120 cond_next870:           ; preds = %LeafBlock1543
121         br i1 false, label %cond_true1012, label %cond_true916
123 cond_true916:           ; preds = %cond_next870
124         ret i32 0
126 cond_true1012:          ; preds = %cond_next870
127         br i1 false, label %cond_next3849, label %cond_true2105
129 cond_true2105:          ; preds = %cond_true1012
130         ret i32 0
132 cond_next3849:          ; preds = %cond_true1012
133         br i1 false, label %cond_next4378, label %bb6559
135 bb3862:         ; preds = %cond_next4385
136         br i1 false, label %cond_false3904, label %cond_true3876
138 cond_true3876:          ; preds = %bb3862
139         ret i32 0
141 cond_false3904:         ; preds = %bb3862
142         br i1 false, label %cond_next4003, label %cond_true3935
144 cond_true3935:          ; preds = %cond_false3904
145         ret i32 0
147 cond_next4003:          ; preds = %cond_false3904
148         br i1 false, label %cond_next5160, label %cond_next4015
150 cond_next4015:          ; preds = %cond_next4003
151         ret i32 0
153 cond_next4378:          ; preds = %cond_next3849
154         br i1 false, label %cond_next4385, label %bb4393
156 cond_next4385:          ; preds = %cond_next4378
157         br i1 false, label %bb3862, label %bb4393
159 bb4393:         ; preds = %cond_next4385, %cond_next4378
160         ret i32 0
162 cond_next5160:          ; preds = %cond_next4003
163         br i1 false, label %bb5188, label %bb6559
165 bb5188:         ; preds = %cond_next5160
166         br i1 false, label %cond_next5285, label %cond_true5210
168 cond_true5210:          ; preds = %bb5188
169         ret i32 0
171 cond_next5285:          ; preds = %bb5188
172         br i1 false, label %cond_true5302, label %cond_true5330
174 cond_true5302:          ; preds = %cond_next5285
175         br i1 false, label %bb7405, label %bb7367
177 cond_true5330:          ; preds = %cond_next5285
178         ret i32 0
180 bb6559:         ; preds = %cond_next5160, %cond_next3849
181         ret i32 0
183 bb7367:         ; preds = %cond_true5302
184         ret i32 0
186 bb7405:         ; preds = %cond_true5302
187         br i1 false, label %cond_next8154, label %cond_true7410
189 cond_true7410:          ; preds = %bb7405
190         ret i32 0
192 cond_next8154:          ; preds = %bb7405
193         br i1 false, label %cond_true8235, label %bb9065
195 cond_true8235:          ; preds = %cond_next8154
196         br i1 false, label %bb8274, label %bb8245
198 bb8245:         ; preds = %cond_true8235
199         ret i32 0
201 bb8274:         ; preds = %cond_true8235
202         br i1 false, label %cond_next8358, label %cond_true8295
204 cond_true8295:          ; preds = %bb8274
205         ret i32 0
207 cond_next8358:          ; preds = %bb8274
208         br i1 false, label %cond_next.i509, label %cond_true8371
210 cond_true8371:          ; preds = %cond_next8358
211         ret i32 -123
213 cond_next.i509:         ; preds = %cond_next8358
214         br i1 false, label %bb36.i, label %bb33.i
216 bb33.i:         ; preds = %cond_next.i509
217         ret i32 0
219 bb36.i:         ; preds = %cond_next.i509
220         br i1 false, label %cond_next54.i, label %cond_true51.i
222 cond_true51.i:          ; preds = %bb36.i
223         ret i32 0
225 cond_next54.i:          ; preds = %bb36.i
226         %tmp10.i.i527 = call i8* @calloc( i64 0, i64 1 )                ; <i8*> [#uses=1]
227         br i1 false, label %cond_next11.i.i, label %bb132.i
229 bb132.i:                ; preds = %cond_next54.i
230         ret i32 0
232 cond_next11.i.i:                ; preds = %cond_next54.i
233         br i1 false, label %bb32.i.i545, label %cond_true1008.critedge.i
235 bb32.i.i545:            ; preds = %cond_next11.i.i
236         br i1 false, label %cond_next349.i, label %cond_true184.i
238 cond_true184.i:         ; preds = %bb32.i.i545
239         ret i32 0
241 cond_next349.i:         ; preds = %bb32.i.i545
242         br i1 false, label %cond_next535.i, label %cond_true1008.critedge1171.i
244 cond_next535.i:         ; preds = %cond_next349.i
245         br i1 false, label %cond_next569.i, label %cond_false574.i
247 cond_next569.i:         ; preds = %cond_next535.i
248         br i1 false, label %cond_next670.i, label %cond_true1008.critedge1185.i
250 cond_false574.i:                ; preds = %cond_next535.i
251         ret i32 0
253 cond_next670.i:         ; preds = %cond_next569.i
254         br i1 false, label %cond_true692.i, label %cond_next862.i
256 cond_true692.i:         ; preds = %cond_next670.i
257         br i1 false, label %cond_false742.i, label %cond_true718.i
259 cond_true718.i:         ; preds = %cond_true692.i
260         ret i32 0
262 cond_false742.i:                ; preds = %cond_true692.i
263         br i1 false, label %cond_true784.i, label %cond_next9079
265 cond_true784.i:         ; preds = %cond_next811.i, %cond_false742.i
266         %indvar1411.i.reg2mem.0 = phi i8 [ %indvar.next1412.i, %cond_next811.i ], [ 0, %cond_false742.i ]               ; <i8> [#uses=1]
267         br i1 false, label %cond_true1008.critedge1190.i, label %cond_next811.i
269 cond_next811.i:         ; preds = %cond_true784.i
270         %indvar.next1412.i = add i8 %indvar1411.i.reg2mem.0, 1          ; <i8> [#uses=2]
271         %tmp781.i = icmp eq i8 %indvar.next1412.i, 3            ; <i1> [#uses=1]
272         br i1 %tmp781.i, label %cond_next9079, label %cond_true784.i
274 cond_next862.i:         ; preds = %cond_next670.i
275         ret i32 0
277 cond_true1008.critedge.i:               ; preds = %cond_next11.i.i
278         ret i32 0
280 cond_true1008.critedge1171.i:           ; preds = %cond_next349.i
281         ret i32 0
283 cond_true1008.critedge1185.i:           ; preds = %cond_next569.i
284         ret i32 0
286 cond_true1008.critedge1190.i:           ; preds = %cond_true784.i
287         %tmp621.i532.lcssa610 = phi i8* [ %tmp10.i.i527, %cond_true784.i ]              ; <i8*> [#uses=0]
288         ret i32 0
290 bb9065:         ; preds = %cond_next8154
291         ret i32 0
293 cond_next9079:          ; preds = %cond_next811.i, %cond_false742.i
294         ret i32 0