[RS4GC] Fix crash in the case that a live variable has a constant base.
[oota-llvm.git] / test / Transforms / JumpThreading / crash.ll
1 ; RUN: opt < %s -jump-threading -disable-output
2 ; PR2285
3 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
4 target triple = "x86_64-unknown-linux-gnu"
5         %struct.system__secondary_stack__mark_id = type { i64, i64 }
6
7 define void @_ada_c35507b() {
8 entry:
9         br label %bb
10
11 bb:             ; preds = %bb13, %entry
12         %ch.0 = phi i8 [ 0, %entry ], [ 0, %bb13 ]              ; <i8> [#uses=1]
13         %tmp11 = icmp ugt i8 %ch.0, 31          ; <i1> [#uses=1]
14         %tmp120 = call %struct.system__secondary_stack__mark_id @system__secondary_stack__ss_mark( )            ; <%struct.system__secondary_stack__mark_id> [#uses=1]
15         br i1 %tmp11, label %bb110, label %bb13
16
17 bb13:           ; preds = %bb
18         br label %bb
19
20 bb110:          ; preds = %bb
21         %mrv_gr124 = extractvalue %struct.system__secondary_stack__mark_id %tmp120, 1           ; <i64> [#uses=0]
22         unreachable
23 }
24
25 declare %struct.system__secondary_stack__mark_id @system__secondary_stack__ss_mark()
26
27
28
29 define fastcc void @findratio(double* nocapture %res1, double* nocapture %res2) nounwind ssp {
30 entry:
31   br label %bb12
32
33 bb6.us:                                        
34   %tmp = icmp eq i32 undef, undef              
35   %tmp1 = fsub double undef, undef             
36   %tmp2 = fcmp ult double %tmp1, 0.000000e+00  
37   br i1 %tmp, label %bb6.us, label %bb13
38
39
40 bb12:                                            
41   %tmp3 = fcmp ult double undef, 0.000000e+00  
42   br label %bb13
43
44 bb13:                                            
45   %.lcssa31 = phi double [ undef, %bb12 ], [ %tmp1, %bb6.us ]
46   %.lcssa30 = phi i1 [ %tmp3, %bb12 ], [ %tmp2, %bb6.us ] 
47   br i1 %.lcssa30, label %bb15, label %bb61
48
49 bb15:                                            
50   %tmp4 = fsub double -0.000000e+00, %.lcssa31   
51   ret void
52
53
54 bb61:                                            
55   ret void
56 }
57
58
59 ; PR5258
60 define i32 @test(i1 %cond, i1 %cond2, i32 %a) {
61 A:
62   br i1 %cond, label %F, label %A1
63 F:
64   br label %A1
65
66 A1:  
67   %d = phi i1 [false, %A], [true, %F]
68   %e = add i32 %a, %a
69   br i1 %d, label %B, label %G
70   
71 G:
72   br i1 %cond2, label %B, label %D
73   
74 B:
75   %f = phi i32 [%e, %G], [%e, %A1]
76   %b = add i32 0, 0
77   switch i32 %a, label %C [
78     i32 7, label %D
79     i32 8, label %D
80     i32 9, label %D
81   ]
82
83 C:
84   br label %D
85   
86 D:
87   %c = phi i32 [%e, %B], [%e, %B], [%e, %B], [%f, %C], [%e, %G]
88   ret i32 %c
89 E:
90   ret i32 412
91 }
92
93
94 define i32 @test2() nounwind {
95 entry:
96         br i1 true, label %decDivideOp.exit, label %bb7.i
97
98 bb7.i:          ; preds = %bb7.i, %entry
99         br label %bb7.i
100
101 decDivideOp.exit:               ; preds = %entry
102         ret i32 undef
103 }
104
105
106 ; PR3298
107
108 define i32 @test3(i32 %p_79, i32 %p_80) nounwind {
109 entry:
110         br label %bb7
111
112 bb1:            ; preds = %bb2
113         br label %bb2
114
115 bb2:            ; preds = %bb7, %bb1
116         %l_82.0 = phi i8 [ 0, %bb1 ], [ %l_82.1, %bb7 ]         ; <i8> [#uses=3]
117         br i1 true, label %bb3, label %bb1
118
119 bb3:            ; preds = %bb2
120         %0 = icmp eq i32 %p_80_addr.1, 0                ; <i1> [#uses=1]
121         br i1 %0, label %bb7, label %bb6
122
123 bb5:            ; preds = %bb6
124         %1 = icmp eq i8 %l_82.0, 0              ; <i1> [#uses=1]
125         br i1 %1, label %bb1.i, label %bb.i
126
127 bb.i:           ; preds = %bb5
128         br label %safe_div_func_char_s_s.exit
129
130 bb1.i:          ; preds = %bb5
131         br label %safe_div_func_char_s_s.exit
132
133 safe_div_func_char_s_s.exit:            ; preds = %bb1.i, %bb.i
134         br label %bb6
135
136 bb6:            ; preds = %safe_div_func_char_s_s.exit, %bb3
137         %p_80_addr.0 = phi i32 [ %p_80_addr.1, %bb3 ], [ 1, %safe_div_func_char_s_s.exit ]              ; <i32> [#uses=2]
138         %2 = icmp eq i32 %p_80_addr.0, 0                ; <i1> [#uses=1]
139         br i1 %2, label %bb7, label %bb5
140
141 bb7:            ; preds = %bb6, %bb3, %entry
142         %l_82.1 = phi i8 [ 1, %entry ], [ %l_82.0, %bb3 ], [ %l_82.0, %bb6 ]            ; <i8> [#uses=2]
143         %p_80_addr.1 = phi i32 [ 0, %entry ], [ %p_80_addr.1, %bb3 ], [ %p_80_addr.0, %bb6 ]            ; <i32> [#uses=4]
144         %3 = icmp eq i32 %p_80_addr.1, 0                ; <i1> [#uses=1]
145         br i1 %3, label %bb8, label %bb2
146
147 bb8:            ; preds = %bb7
148         %4 = sext i8 %l_82.1 to i32             ; <i32> [#uses=0]
149         ret i32 0
150 }
151
152
153 ; PR3353
154
155 define i32 @test4(i8 %X) {
156 entry:
157         %Y = add i8 %X, 1
158         %Z = add i8 %Y, 1
159         br label %bb33.i
160
161 bb33.i:         ; preds = %bb33.i, %bb32.i
162         switch i8 %Y, label %bb32.i [
163                 i8 39, label %bb35.split.i
164                 i8 13, label %bb33.i
165         ]
166
167 bb35.split.i:
168         ret i32 5
169 bb32.i:
170         ret i32 1
171 }
172
173
174 define fastcc void @test5(i1 %tmp, i32 %tmp1) nounwind ssp {
175 entry:
176   br i1 %tmp, label %bb12, label %bb13
177
178
179 bb12:                                            
180   br label %bb13
181
182 bb13:                                            
183   %.lcssa31 = phi i32 [ undef, %bb12 ], [ %tmp1, %entry ]
184   %A = and i1 undef, undef
185   br i1 %A, label %bb15, label %bb61
186
187 bb15:                                            
188   ret void
189
190
191 bb61:                                            
192   ret void
193 }
194
195
196 ; PR5640
197 define fastcc void @test6(i1 %tmp, i1 %tmp1) nounwind ssp {
198 entry:
199   br i1 %tmp, label %bb12, label %bb14
200
201 bb12:           
202   br label %bb14
203
204 bb14:           
205   %A = phi i1 [ %A, %bb13 ],  [ true, %bb12 ], [%tmp1, %entry]
206   br label %bb13
207
208 bb13:                                            
209   br i1 %A, label %bb14, label %bb61
210
211
212 bb61:                                            
213   ret void
214 }
215
216
217 ; PR5698
218 define void @test7(i32 %x) {
219 entry:
220   br label %tailrecurse
221
222 tailrecurse:
223   switch i32 %x, label %return [
224     i32 2, label %bb2
225     i32 3, label %bb
226   ]
227
228 bb:         
229   switch i32 %x, label %return [
230     i32 2, label %bb2
231     i32 3, label %tailrecurse
232   ]
233
234 bb2:        
235   ret void
236
237 return:     
238   ret void
239 }
240
241 ; PR6119
242 define i32 @test8(i32 %action) nounwind {
243 entry:
244   switch i32 %action, label %lor.rhs [
245     i32 1, label %if.then
246     i32 0, label %lor.end
247   ]
248
249 if.then:                                          ; preds = %for.cond, %lor.end, %entry
250   ret i32 undef
251
252 lor.rhs:                                          ; preds = %entry
253   br label %lor.end
254
255 lor.end:                                          ; preds = %lor.rhs, %entry
256   %cmp103 = xor i1 undef, undef                   ; <i1> [#uses=1]
257   br i1 %cmp103, label %for.cond, label %if.then
258
259 for.cond:                                         ; preds = %for.body, %lor.end
260   br i1 undef, label %if.then, label %for.body
261
262 for.body:                                         ; preds = %for.cond
263   br label %for.cond
264 }
265
266 ; PR6119
267 define i32 @test9(i32 %action) nounwind {
268 entry:
269   switch i32 %action, label %lor.rhs [
270     i32 1, label %if.then
271     i32 0, label %lor.end
272   ]
273
274 if.then:                                          ; preds = %for.cond, %lor.end, %entry
275   ret i32 undef
276
277 lor.rhs:                                          ; preds = %entry
278   br label %lor.end
279
280 lor.end:                                          ; preds = %lor.rhs, %entry
281   %0 = phi i1 [ undef, %lor.rhs ], [ true, %entry ] ; <i1> [#uses=1]
282   %cmp103 = xor i1 undef, %0                      ; <i1> [#uses=1]
283   br i1 %cmp103, label %for.cond, label %if.then
284
285 for.cond:                                         ; preds = %for.body, %lor.end
286   br i1 undef, label %if.then, label %for.body
287
288 for.body:                                         ; preds = %for.cond
289   br label %for.cond
290 }
291
292 ; PR6119
293 define i32 @test10(i32 %action, i32 %type) nounwind {
294 entry:
295   %cmp2 = icmp eq i32 %type, 0                    ; <i1> [#uses=1]
296   switch i32 %action, label %lor.rhs [
297     i32 1, label %if.then
298     i32 0, label %lor.end
299   ]
300
301 if.then:                                          ; preds = %for.cond, %lor.end, %entry
302   ret i32 undef
303
304 lor.rhs:                                          ; preds = %entry
305   %cmp101 = icmp eq i32 %action, 2                ; <i1> [#uses=1]
306   br label %lor.end
307
308 lor.end:                                          ; preds = %lor.rhs, %entry
309   %0 = phi i1 [ %cmp101, %lor.rhs ], [ true, %entry ] ; <i1> [#uses=1]
310   %cmp103 = xor i1 %cmp2, %0                      ; <i1> [#uses=1]
311   br i1 %cmp103, label %for.cond, label %if.then
312
313 for.cond:                                         ; preds = %for.body, %lor.end
314   br i1 undef, label %if.then, label %for.body
315
316 for.body:                                         ; preds = %for.cond
317   br label %for.cond
318 }
319
320
321 ; PR6305
322 define void @test11() nounwind {
323 entry:
324   br label %A
325
326 A:                                             ; preds = %entry
327   call void undef(i64 ptrtoint (i8* blockaddress(@test11, %A) to i64)) nounwind
328   unreachable
329 }
330
331 ; PR6743
332 define void @test12() nounwind ssp {
333 entry:
334   br label %lbl_51
335
336 lbl_51:                                           ; preds = %if.then, %entry
337   %tmp3 = phi i1 [ false, %if.then ], [ undef, %entry ] ; <i1> [#uses=2]
338   br i1 %tmp3, label %if.end12, label %if.then
339
340 if.then:                                          ; preds = %lbl_51
341   br i1 %tmp3, label %lbl_51, label %if.end12
342
343 if.end12:                                         ; preds = %if.then, %lbl_51
344   ret void
345 }
346
347
348
349 ; PR7356
350 define i32 @test13(i32* %P, i8* %Ptr) {
351 entry:
352   indirectbr i8* %Ptr, [label %BrBlock, label %B2]
353   
354 B2:
355   store i32 4, i32 *%P
356   br label %BrBlock
357
358 BrBlock:
359   %L = load i32, i32* %P
360   %C = icmp eq i32 %L, 42
361   br i1 %C, label %T, label %F
362   
363 T:
364   ret i32 123
365 F:
366   ret i32 1422
367 }
368
369
370 ; PR7498
371 define void @test14() nounwind {
372 entry:
373   %cmp33 = icmp slt i8 undef, 0                   ; <i1> [#uses=1]
374   %tobool = icmp eq i8 undef, 0                   ; <i1> [#uses=1]
375   br i1 %tobool, label %land.end69, label %land.rhs
376
377 land.rhs:                                         ; preds = %entry
378   br label %land.end69
379
380 land.end69:                                       ; preds = %land.rhs, %entry
381   %0 = phi i1 [ undef, %land.rhs ], [ true, %entry ] ; <i1> [#uses=1]
382   %cmp71 = or i1 true, %0                         ; <i1> [#uses=1]
383   %cmp73 = xor i1 %cmp33, %cmp71                  ; <i1> [#uses=1]
384   br i1 %cmp73, label %if.then, label %if.end
385
386 if.then:                                          ; preds = %land.end69
387   ret void
388
389 if.end:                                           ; preds = %land.end69
390   ret void
391 }
392
393 ; PR7647
394 define void @test15() nounwind {
395 entry:
396   ret void
397   
398 if.then237:
399   br label %lbl_664
400
401 lbl_596:                                          ; preds = %lbl_664, %for.end37
402   store volatile i64 undef, i64* undef, align 4
403   br label %for.cond111
404
405 for.cond111:                                      ; preds = %safe_sub_func_int64_t_s_s.exit, %lbl_596
406   %storemerge = phi i8 [ undef, %cond.true.i100 ], [ 22, %lbl_596 ] ; <i8> [#uses=1]
407   %l_678.5 = phi i64 [ %l_678.3, %cond.true.i100 ], [ undef, %lbl_596 ] ; <i64> [#uses=2]
408   %cmp114 = icmp slt i8 %storemerge, -2           ; <i1> [#uses=1]
409   br i1 %cmp114, label %lbl_664, label %if.end949
410
411 lbl_664:                                          ; preds = %for.end1058, %if.then237, %for.cond111
412   %l_678.3 = phi i64 [ %l_678.5, %for.cond111 ], [ %l_678.2, %for.cond1035 ], [ 5, %if.then237 ] ; <i64> [#uses=1]
413   %tobool118 = icmp eq i32 undef, 0               ; <i1> [#uses=1]
414   br i1 %tobool118, label %cond.true.i100, label %lbl_596
415
416 cond.true.i100:                                   ; preds = %for.inc120
417   br label %for.cond111
418
419 lbl_709:
420   br label %if.end949
421   
422 for.cond603:                                      ; preds = %for.body607, %if.end336
423   br i1 undef, label %for.cond603, label %if.end949
424
425 if.end949:                                        ; preds = %for.cond603, %lbl_709, %for.cond111
426   %l_678.2 = phi i64 [ %l_678.5, %for.cond111 ], [ undef, %lbl_709 ], [ 5, %for.cond603 ] ; <i64> [#uses=1]
427   br label %for.body1016
428
429 for.body1016:                                     ; preds = %for.cond1012
430   br label %for.body1016
431
432 for.cond1035:                                     ; preds = %for.inc1055, %if.then1026
433   br i1 undef, label %for.cond1040, label %lbl_664
434
435 for.cond1040:                                     ; preds = %for.body1044, %for.cond1035
436   ret void
437 }
438
439 ; PR7755
440 define void @test16(i1 %c, i1 %c2, i1 %c3, i1 %c4) nounwind ssp {
441 entry:
442   %cmp = icmp sgt i32 undef, 1                    ; <i1> [#uses=1]
443   br i1 %c, label %land.end, label %land.rhs
444
445 land.rhs:                                         ; preds = %entry
446   br i1 %c2, label %lor.lhs.false.i, label %land.end
447
448 lor.lhs.false.i:                                  ; preds = %land.rhs
449   br i1 %c3, label %land.end, label %land.end
450
451 land.end:                            
452   %0 = phi i1 [ true, %entry ], [ false, %land.rhs ], [false, %lor.lhs.false.i], [false, %lor.lhs.false.i] ; <i1> [#uses=1]
453   %cmp12 = and i1 %cmp, %0 
454   %xor1 = xor i1 %cmp12, %c4
455   br i1 %xor1, label %if.then, label %if.end
456
457 if.then:                      
458   ret void
459
460 if.end:                       
461   ret void
462 }
463
464 define void @test17() {
465 entry:
466   br i1 undef, label %bb269.us.us, label %bb269.us.us.us
467
468 bb269.us.us.us:
469   %indvar = phi i64 [ %indvar.next, %bb287.us.us.us ], [ 0, %entry ]
470   %0 = icmp eq i16 undef, 0
471   br i1 %0, label %bb287.us.us.us, label %bb286.us.us.us
472
473 bb287.us.us.us:
474   %indvar.next = add i64 %indvar, 1
475   %exitcond = icmp eq i64 %indvar.next, 4
476   br i1 %exitcond, label %bb288.bb289.loopexit_crit_edge, label %bb269.us.us.us
477
478 bb286.us.us.us:
479   unreachable
480
481 bb269.us.us:
482         unreachable
483
484 bb288.bb289.loopexit_crit_edge:
485   unreachable
486 }
487
488 ; PR 8247
489 %struct.S1 = type { i8, i8 }
490 @func_89.l_245 = internal constant %struct.S1 { i8 33, i8 6 }, align 1
491 define void @func_89(i16 zeroext %p_90, %struct.S1* nocapture %p_91, i32* nocapture %p_92) nounwind ssp {
492 entry:
493   store i32 0, i32* %p_92, align 4
494   br i1 false, label %lbl_260, label %if.else
495
496 if.else:                                          ; preds = %entry
497   br label %for.cond
498
499 for.cond:                                         ; preds = %lbl_260, %if.else
500   %l_245.0 = phi i16 [ %l_245.1, %lbl_260 ], [ 33, %if.else ]
501   %l_261.0 = phi i32 [ %and, %lbl_260 ], [ 255, %if.else ]
502   %tobool21 = icmp ult i16 %l_245.0, 256
503   br i1 %tobool21, label %if.end, label %lbl_260
504
505 lbl_260:                                          ; preds = %for.cond, %entry
506   %l_245.1 = phi i16 [ 1569, %entry ], [ %l_245.0, %for.cond ]
507   %l_261.1 = phi i32 [ 255, %entry ], [ %l_261.0, %for.cond ]
508   %and = and i32 %l_261.1, 1
509   br label %for.cond
510
511 if.end:                                           ; preds = %for.cond
512   ret void
513 }
514
515 define void @PR14233(i1 %cmp, i1 %cmp2, i1 %cmp3, i1 %cmp4) {
516 entry:
517   br i1 %cmp, label %cond.true, label %cond.false
518
519 cond.true:
520   br label %if.end
521
522 cond.false:
523   br label %if.end
524
525 if.end:
526   %A = phi i64 [ 0, %cond.true ], [ 1, %cond.false ]
527   br i1 %cmp2, label %bb, label %if.end2
528
529 bb:
530   br label %if.end2
531
532 if.end2:
533   %B = phi i64 [ ptrtoint (i8* ()* @PR14233.f1 to i64), %bb ], [ %A, %if.end ]
534   %cmp.ptr = icmp eq i64 %B, ptrtoint (i8* ()* @PR14233.f2 to i64)
535   br i1 %cmp.ptr, label %cond.true2, label %if.end3
536
537 cond.true2:
538   br i1 %cmp3, label %bb2, label %ur
539
540 bb2:
541   br i1 %cmp4, label %if.end4, label %if.end3
542
543 if.end4:
544   unreachable
545
546 if.end3:
547   %cmp.ptr2 = icmp eq i64 %B, ptrtoint (i8* ()* @PR14233.f2 to i64)
548   br i1 %cmp.ptr2, label %ur, label %if.then601
549
550 if.then601:
551   %C = icmp eq i64 %B, 0
552   br i1 %C, label %bb3, label %bb4
553
554 bb3:
555   unreachable
556
557 bb4:
558   unreachable
559
560 ur:
561   unreachable
562 }
563
564 declare i8* @PR14233.f1()
565
566 declare i8* @PR14233.f2()