[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / WebAssembly / cfg-stackify.ll
blob6e0bbce78a1ae4d98cbe79f0850192f9c4fcb35e
1 ; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -disable-block-placement -verify-machineinstrs -fast-isel=false -machine-sink-split-probability-threshold=0 -cgp-freq-ratio-to-skip-merge=1000 | FileCheck %s
3 ; Test the CFG stackifier pass.
5 ; Explicitly disable fast-isel, since it gets implicitly enabled in the
6 ; optnone test.
8 target triple = "wasm32-unknown-unknown"
10 declare void @something()
12 ; Test that loops are made contiguous, even in the presence of split backedges.
14 ; CHECK-LABEL: test0:
15 ; CHECK: loop
16 ; CHECK-NEXT: block
17 ; CHECK:      i32.lt_s
18 ; CHECK-NEXT: br_if
19 ; CHECK-NEXT: return
20 ; CHECK-NEXT: .LBB{{[0-9]+}}_3:
21 ; CHECK-NEXT: end_block
22 ; CHECK-NEXT: i32.const
23 ; CHECK-NEXT: i32.add
24 ; CHECK-NEXT: call
25 ; CHECK-NEXT: br
26 ; CHECK-NEXT: .LBB{{[0-9]+}}_4:
27 ; CHECK-NEXT: end_loop
28 define void @test0(i32 %n) {
29 entry:
30   br label %header
32 header:
33   %i = phi i32 [ 0, %entry ], [ %i.next, %back ]
34   %i.next = add i32 %i, 1
36   %c = icmp slt i32 %i.next, %n
37   br i1 %c, label %back, label %exit
39 exit:
40   ret void
42 back:
43   call void @something()
44   br label %header
47 ; Same as test0, but the branch condition is reversed.
49 ; CHECK-LABEL: test1:
50 ; CHECK: loop
51 ; CHECK-NEXT: block
52 ; CHECK:      i32.lt_s
53 ; CHECK-NEXT: br_if
54 ; CHECK-NEXT: return
55 ; CHECK-NEXT: .LBB{{[0-9]+}}_3:
56 ; CHECK-NEXT: end_block
57 ; CHECK-NEXT: i32.const
58 ; CHECK-NEXT: i32.add
59 ; CHECK-NEXT: call
60 ; CHECK-NEXT: br
61 ; CHECK-NEXT: .LBB{{[0-9]+}}_4:
62 ; CHECK-NEXT: end_loop
63 define void @test1(i32 %n) {
64 entry:
65   br label %header
67 header:
68   %i = phi i32 [ 0, %entry ], [ %i.next, %back ]
69   %i.next = add i32 %i, 1
71   %c = icmp sge i32 %i.next, %n
72   br i1 %c, label %exit, label %back
74 exit:
75   ret void
77 back:
78   call void @something()
79   br label %header
82 ; Test that a simple loop is handled as expected.
84 ; CHECK-LABEL: test2:
85 ; CHECK-NOT: local
86 ; CHECK: block   {{$}}
87 ; CHECK: br_if 0, {{[^,]+}}{{$}}
88 ; CHECK: .LBB{{[0-9]+}}_{{[0-9]+}}:
89 ; CHECK: loop
90 ; CHECK: br_if 0, $pop{{[0-9]+}}{{$}}
91 ; CHECK: .LBB{{[0-9]+}}_{{[0-9]+}}:
92 ; CHECK: end_loop
93 ; CHECK: end_block
94 ; CHECK: return{{$}}
95 define void @test2(double* nocapture %p, i32 %n) {
96 entry:
97   %cmp.4 = icmp sgt i32 %n, 0
98   br i1 %cmp.4, label %for.body.preheader, label %for.end
100 for.body.preheader:
101   br label %for.body
103 for.body:
104   %i.05 = phi i32 [ %inc, %for.body ], [ 0, %for.body.preheader ]
105   %arrayidx = getelementptr inbounds double, double* %p, i32 %i.05
106   %0 = load double, double* %arrayidx, align 8
107   %mul = fmul double %0, 3.200000e+00
108   store double %mul, double* %arrayidx, align 8
109   %inc = add nuw nsw i32 %i.05, 1
110   %exitcond = icmp eq i32 %inc, %n
111   br i1 %exitcond, label %for.end.loopexit, label %for.body
113 for.end.loopexit:
114   br label %for.end
116 for.end:
117   ret void
120 ; CHECK-LABEL: doublediamond:
121 ; CHECK: block   {{$}}
122 ; CHECK-NEXT: block   {{$}}
123 ; CHECK: br_if 0, ${{[^,]+}}{{$}}
124 ; CHECK: br 1{{$}}
125 ; CHECK: .LBB{{[0-9]+}}_2:
126 ; CHECK-NEXT: end_block{{$}}
127 ; CHECK: block   {{$}}
128 ; CHECK: br_if 0, ${{[^,]+}}{{$}}
129 ; CHECK: br 1{{$}}
130 ; CHECK: .LBB{{[0-9]+}}_4:
131 ; CHECK-NEXT: end_block{{$}}
132 ; CHECK: .LBB{{[0-9]+}}_5:
133 ; CHECK-NEXT: end_block{{$}}
134 ; CHECK: i32.const $push{{[0-9]+}}=, 0{{$}}
135 ; CHECK-NEXT: return $pop{{[0-9]+}}{{$}}
136 define i32 @doublediamond(i32 %a, i32 %b, i32* %p) {
137 entry:
138   %c = icmp eq i32 %a, 0
139   %d = icmp eq i32 %b, 0
140   store volatile i32 0, i32* %p
141   br i1 %c, label %true, label %false
142 true:
143   store volatile i32 1, i32* %p
144   br label %exit
145 false:
146   store volatile i32 2, i32* %p
147   br i1 %d, label %ft, label %ff
149   store volatile i32 3, i32* %p
150   br label %exit
152   store volatile i32 4, i32* %p
153   br label %exit
154 exit:
155   store volatile i32 5, i32* %p
156   ret i32 0
159 ; CHECK-LABEL: triangle:
160 ; CHECK: block   {{$}}
161 ; CHECK: br_if 0, $1{{$}}
162 ; CHECK: .LBB{{[0-9]+}}_2:
163 ; CHECK: return
164 define i32 @triangle(i32* %p, i32 %a) {
165 entry:
166   %c = icmp eq i32 %a, 0
167   store volatile i32 0, i32* %p
168   br i1 %c, label %true, label %exit
169 true:
170   store volatile i32 1, i32* %p
171   br label %exit
172 exit:
173   store volatile i32 2, i32* %p
174   ret i32 0
177 ; CHECK-LABEL: diamond:
178 ; CHECK: block   {{$}}
179 ; CHECK: block   {{$}}
180 ; CHECK: br_if 0, $1{{$}}
181 ; CHECK: br 1{{$}}
182 ; CHECK: .LBB{{[0-9]+}}_2:
183 ; CHECK: .LBB{{[0-9]+}}_3:
184 ; CHECK: i32.const $push{{[0-9]+}}=, 0{{$}}
185 ; CHECK-NEXT: return $pop{{[0-9]+}}{{$}}
186 define i32 @diamond(i32* %p, i32 %a) {
187 entry:
188   %c = icmp eq i32 %a, 0
189   store volatile i32 0, i32* %p
190   br i1 %c, label %true, label %false
191 true:
192   store volatile i32 1, i32* %p
193   br label %exit
194 false:
195   store volatile i32 2, i32* %p
196   br label %exit
197 exit:
198   store volatile i32 3, i32* %p
199   ret i32 0
202 ; CHECK-LABEL: single_block:
203 ; CHECK-NOT: br
204 ; CHECK: return $pop{{[0-9]+}}{{$}}
205 define i32 @single_block(i32* %p) {
206 entry:
207   store volatile i32 0, i32* %p
208   ret i32 0
211 ; CHECK-LABEL: minimal_loop:
212 ; CHECK-NOT: br
213 ; CHECK: .LBB{{[0-9]+}}_1:
214 ; CHECK: loop i32
215 ; CHECK: i32.store 0($0), $pop{{[0-9]+}}{{$}}
216 ; CHECK: br 0{{$}}
217 ; CHECK: .LBB{{[0-9]+}}_2:
218 define i32 @minimal_loop(i32* %p) {
219 entry:
220   store volatile i32 0, i32* %p
221   br label %loop
222 loop:
223   store volatile i32 1, i32* %p
224   br label %loop
227 ; CHECK-LABEL: simple_loop:
228 ; CHECK-NOT: br
229 ; CHECK: .LBB{{[0-9]+}}_1:
230 ; CHECK: loop    {{$}}
231 ; CHECK: br_if 0, $pop{{[0-9]+}}{{$}}
232 ; CHECK-NEXT: end_loop{{$}}
233 ; CHECK: i32.const $push{{[0-9]+}}=, 0{{$}}
234 ; CHECK-NEXT: return $pop{{[0-9]+}}{{$}}
235 define i32 @simple_loop(i32* %p, i32 %a) {
236 entry:
237   %c = icmp eq i32 %a, 0
238   store volatile i32 0, i32* %p
239   br label %loop
240 loop:
241   store volatile i32 1, i32* %p
242   br i1 %c, label %loop, label %exit
243 exit:
244   store volatile i32 2, i32* %p
245   ret i32 0
248 ; CHECK-LABEL: doubletriangle:
249 ; CHECK: block   {{$}}
250 ; CHECK: br_if 0, $0{{$}}
251 ; CHECK: block   {{$}}
252 ; CHECK: br_if 0, $1{{$}}
253 ; CHECK: .LBB{{[0-9]+}}_3:
254 ; CHECK: .LBB{{[0-9]+}}_4:
255 ; CHECK: return
256 define i32 @doubletriangle(i32 %a, i32 %b, i32* %p) {
257 entry:
258   %c = icmp eq i32 %a, 0
259   %d = icmp eq i32 %b, 0
260   store volatile i32 0, i32* %p
261   br i1 %c, label %true, label %exit
262 true:
263   store volatile i32 2, i32* %p
264   br i1 %d, label %tt, label %tf
266   store volatile i32 3, i32* %p
267   br label %tf
269   store volatile i32 4, i32* %p
270   br label %exit
271 exit:
272   store volatile i32 5, i32* %p
273   ret i32 0
276 ; CHECK-LABEL: ifelse_earlyexits:
277 ; CHECK: block   {{$}}
278 ; CHECK: block   {{$}}
279 ; CHECK: br_if 0, $0{{$}}
280 ; CHECK: br 1{{$}}
281 ; CHECK: .LBB{{[0-9]+}}_2:
282 ; CHECK: br_if 0, $1{{$}}
283 ; CHECK: .LBB{{[0-9]+}}_4:
284 ; CHECK: i32.const $push{{[0-9]+}}=, 0{{$}}
285 ; CHECK-NEXT: return $pop{{[0-9]+}}{{$}}
286 define i32 @ifelse_earlyexits(i32 %a, i32 %b, i32* %p) {
287 entry:
288   %c = icmp eq i32 %a, 0
289   %d = icmp eq i32 %b, 0
290   store volatile i32 0, i32* %p
291   br i1 %c, label %true, label %false
292 true:
293   store volatile i32 1, i32* %p
294   br label %exit
295 false:
296   store volatile i32 2, i32* %p
297   br i1 %d, label %ft, label %exit
299   store volatile i32 3, i32* %p
300   br label %exit
301 exit:
302   store volatile i32 4, i32* %p
303   ret i32 0
306 ; CHECK-LABEL: doublediamond_in_a_loop:
307 ; CHECK: .LBB{{[0-9]+}}_1:
308 ; CHECK: loop i32{{$}}
309 ; CHECK: block   {{$}}
310 ; CHECK: br_if           0, $0{{$}}
311 ; CHECK: br              1{{$}}
312 ; CHECK: .LBB{{[0-9]+}}_3:
313 ; CHECK: end_block{{$}}
314 ; CHECK: block   {{$}}
315 ; CHECK: br_if           0, $1{{$}}
316 ; CHECK: br              1{{$}}
317 ; CHECK: .LBB{{[0-9]+}}_5:
318 ; CHECK: br              0{{$}}
319 ; CHECK: .LBB{{[0-9]+}}_6:
320 ; CHECK-NEXT: end_loop{{$}}
321 define i32 @doublediamond_in_a_loop(i32 %a, i32 %b, i32* %p) {
322 entry:
323   br label %header
324 header:
325   %c = icmp eq i32 %a, 0
326   %d = icmp eq i32 %b, 0
327   store volatile i32 0, i32* %p
328   br i1 %c, label %true, label %false
329 true:
330   store volatile i32 1, i32* %p
331   br label %exit
332 false:
333   store volatile i32 2, i32* %p
334   br i1 %d, label %ft, label %ff
336   store volatile i32 3, i32* %p
337   br label %exit
339   store volatile i32 4, i32* %p
340   br label %exit
341 exit:
342   store volatile i32 5, i32* %p
343   br label %header
346 ; Test that nested loops are handled.
348 ; CHECK-LABEL: test3:
349 ; CHECK: loop
350 ; CHECK-NEXT: br_if
351 ; CHECK-NEXT: .LBB{{[0-9]+}}_{{[0-9]+}}:
352 ; CHECK-NEXT: loop
353 declare void @bar()
354 define void @test3(i32 %w, i32 %x)  {
355 entry:
356   br i1 undef, label %outer.ph, label %exit
358 outer.ph:
359   br label %outer
361 outer:
362   %tobool = icmp eq i32 %x, 0
363   br i1 %tobool, label %inner, label %unreachable
365 unreachable:
366   unreachable
368 inner:
369   %c = icmp eq i32 %x, %w
370   br i1 %c, label %if.end, label %inner
372 exit:
373   ret void
375 if.end:
376   call void @bar()
377   br label %outer
380 ; Test switch lowering and block placement.
382 ; CHECK-LABEL: test4:
383 ; CHECK-NEXT: .functype test4 (i32) -> (){{$}}
384 ; CHECK-NEXT: block   {{$}}
385 ; CHECK-NEXT: block   {{$}}
386 ; CHECK-NEXT: br_table   $0, 1, 1, 1, 1, 1, 0{{$}}
387 ; CHECK-NEXT: .LBB{{[0-9]+}}_1:
388 ; CHECK-NEXT: end_block{{$}}
389 ; CHECK-NEXT: i32.const $push[[C:[0-9]+]]=, 622{{$}}
390 ; CHECK-NEXT: i32.eq $drop=, $0, $pop[[C]]{{$}}
391 ; CHECK-NEXT: .LBB{{[0-9]+}}_2:
392 ; CHECK-NEXT: end_block{{$}}
393 ; CHECK-NEXT: return{{$}}
394 define void @test4(i32 %t) {
395 entry:
396   switch i32 %t, label %default [
397     i32 0, label %bb2
398     i32 2, label %bb2
399     i32 4, label %bb1
400     i32 622, label %bb0
401   ]
403 bb0:
404   ret void
406 bb1:
407   ret void
409 bb2:
410   ret void
412 default:
413   ret void
416 ; Test a case where the BLOCK needs to be placed before the LOOP in the
417 ; same basic block.
419 ; CHECK-LABEL: test5:
420 ; CHECK:       .LBB{{[0-9]+}}_1:
421 ; CHECK-NEXT:  block   {{$}}
422 ; CHECK-NEXT:  loop    {{$}}
423 ; CHECK:       br_if 1, {{[^,]+}}{{$}}
424 ; CHECK:       br_if 0, {{[^,]+}}{{$}}
425 ; CHECK-NEXT:  end_loop{{$}}
426 ; CHECK:       return{{$}}
427 ; CHECK-NEXT:  .LBB{{[0-9]+}}_4:
428 ; CHECK:       return{{$}}
429 define void @test5(i1 %p, i1 %q) {
430 entry:
431   br label %header
433 header:
434   store volatile i32 0, i32* null
435   br i1 %p, label %more, label %alt
437 more:
438   store volatile i32 1, i32* null
439   br i1 %q, label %header, label %return
441 alt:
442   store volatile i32 2, i32* null
443   ret void
445 return:
446   store volatile i32 3, i32* null
447   ret void
450 ; Test an interesting case of a loop with multiple exits, which
451 ; aren't to layout successors of the loop, and one of which is to a successors
452 ; which has another predecessor.
454 ; CHECK-LABEL: test6:
455 ; CHECK:       .LBB{{[0-9]+}}_1:
456 ; CHECK-NEXT:  block   {{$}}
457 ; CHECK-NEXT:  block   {{$}}
458 ; CHECK-NEXT:  loop    {{$}}
459 ; CHECK-NOT:   block
460 ; CHECK:       br_if 2, {{[^,]+}}{{$}}
461 ; CHECK-NOT:   block
462 ; CHECK:       br_if 1, {{[^,]+}}{{$}}
463 ; CHECK-NOT:   block
464 ; CHECK:       br_if 0, {{[^,]+}}{{$}}
465 ; CHECK-NEXT:  end_loop{{$}}
466 ; CHECK-NOT:   block
467 ; CHECK:       return{{$}}
468 ; CHECK-NEXT:  .LBB{{[0-9]+}}_5:
469 ; CHECK-NEXT:  end_block{{$}}
470 ; CHECK-NOT:   block
471 ; CHECK:       .LBB{{[0-9]+}}_6:
472 ; CHECK-NEXT:  end_block{{$}}
473 ; CHECK-NOT:   block
474 ; CHECK:       return{{$}}
475 define void @test6(i1 %p, i1 %q) {
476 entry:
477   br label %header
479 header:
480   store volatile i32 0, i32* null
481   br i1 %p, label %more, label %second
483 more:
484   store volatile i32 1, i32* null
485   br i1 %q, label %evenmore, label %first
487 evenmore:
488   store volatile i32 1, i32* null
489   br i1 %q, label %header, label %return
491 return:
492   store volatile i32 2, i32* null
493   ret void
495 first:
496   store volatile i32 3, i32* null
497   br label %second
499 second:
500   store volatile i32 4, i32* null
501   ret void
504 ; Test a case where there are multiple backedges and multiple loop exits
505 ; that end in unreachable.
507 ; CHECK-LABEL: test7:
508 ; CHECK:       .LBB{{[0-9]+}}_1:
509 ; CHECK-NEXT:  loop    {{$}}
510 ; CHECK-NOT:   block
511 ; CHECK:       block   {{$}}
512 ; CHECK:       br_if 0, {{[^,]+}}{{$}}
513 ; CHECK-NOT:   block
514 ; CHECK:       br_if 1, {{[^,]+}}{{$}}
515 ; CHECK-NOT:   block
516 ; CHECK:       unreachable
517 ; CHECK-NEXT:  .LBB{{[0-9]+}}_4:
518 ; CHECK-NEXT:  end_block{{$}}
519 ; CHECK-NOT:   block
520 ; CHECK:       br_if 0, {{[^,]+}}{{$}}
521 ; CHECK-NEXT:  end_loop{{$}}
522 ; CHECK-NOT:   block
523 ; CHECK:       unreachable
524 define void @test7(i1 %tobool2, i1 %tobool9) {
525 entry:
526   store volatile i32 0, i32* null
527   br label %loop
529 loop:
530   store volatile i32 1, i32* null
531   br i1 %tobool2, label %l1, label %l0
534   store volatile i32 2, i32* null
535   br i1 %tobool9, label %loop, label %u0
538   store volatile i32 3, i32* null
539   br i1 %tobool9, label %loop, label %u1
542   store volatile i32 4, i32* null
543   unreachable
546   store volatile i32 5, i32* null
547   unreachable
550 ; Test an interesting case using nested loops and switches.
552 ; CHECK-LABEL: test8:
553 ; CHECK:       .LBB{{[0-9]+}}_1:
554 ; CHECK-NEXT:  loop i32{{$}}
555 ; CHECK-NEXT:  i32.const $push{{[^,]+}}, 0{{$}}
556 ; CHECK-NEXT:  br_if    0, {{[^,]+}}{{$}}
557 ; CHECK-NEXT:  br       0{{$}}
558 ; CHECK-NEXT:  .LBB{{[0-9]+}}_2:
559 ; CHECK-NEXT:  end_loop{{$}}
560 define i32 @test8() {
562   br label %bb1
564 bb1:
565   br i1 undef, label %bb2, label %bb3
567 bb2:
568   switch i8 undef, label %bb1 [
569     i8 44, label %bb2
570   ]
572 bb3:
573   switch i8 undef, label %bb1 [
574     i8 44, label %bb2
575   ]
578 ; Test an interesting case using nested loops that share a bottom block.
580 ; CHECK-LABEL: test9:
581 ; CHECK:       .LBB{{[0-9]+}}_1:
582 ; CHECK-NEXT:  block   {{$}}
583 ; CHECK-NEXT:  loop    {{$}}
584 ; CHECK-NOT:   block
585 ; CHECK:       br_if     1, {{[^,]+}}{{$}}
586 ; CHECK-NEXT:  .LBB{{[0-9]+}}_2:
587 ; CHECK-NEXT:  loop    {{$}}
588 ; CHECK-NOT:   block
589 ; CHECK:       block   {{$}}
590 ; CHECK-NOT:   block
591 ; CHECK:       br_if     0, {{[^,]+}}{{$}}
592 ; CHECK-NOT:   block
593 ; CHECK:       br_if     2, {{[^,]+}}{{$}}
594 ; CHECK-NEXT:  br        1{{$}}
595 ; CHECK-NEXT:  .LBB{{[0-9]+}}_4:
596 ; CHECK-NEXT:  end_block{{$}}
597 ; CHECK-NOT:   block
598 ; CHECK:       br_if     1, {{[^,]+}}{{$}}
599 ; CHECK-NEXT:  br        0{{$}}
600 ; CHECK-NEXT:  .LBB{{[0-9]+}}_5:
601 ; CHECK-NOT:   block
602 ; CHECK:       end_block
603 ; CHECK-NOT:   block
604 ; CHECK:       return{{$}}
605 declare i1 @a()
606 define void @test9() {
607 entry:
608   store volatile i32 0, i32* null
609   br label %header
611 header:
612   store volatile i32 1, i32* null
613   %call4 = call i1 @a()
614   br i1 %call4, label %header2, label %end
616 header2:
617   store volatile i32 2, i32* null
618   %call = call i1 @a()
619   br i1 %call, label %if.then, label %if.else
621 if.then:
622   store volatile i32 3, i32* null
623   %call3 = call i1 @a()
624   br i1 %call3, label %header2, label %header
626 if.else:
627   store volatile i32 4, i32* null
628   %call2 = call i1 @a()
629   br i1 %call2, label %header2, label %header
631 end:
632   store volatile i32 5, i32* null
633   ret void
636 ; Test an interesting case involving nested loops sharing a loop bottom,
637 ; and loop exits to a block with unreachable.
639 ; CHECK-LABEL: test10:
640 ; CHECK:       .LBB{{[0-9]+}}_1:
641 ; CHECK-NEXT:  loop    {{$}}
642 ; CHECK:       br_if     0, {{[^,]+}}{{$}}
643 ; CHECK:       .LBB{{[0-9]+}}_3:
644 ; CHECK-NEXT:  block   {{$}}
645 ; CHECK-NEXT:  loop    {{$}}
646 ; CHECK:       .LBB{{[0-9]+}}_4:
647 ; CHECK-NEXT:  loop    {{$}}
648 ; CHECK:       br_if     0, {{[^,]+}}{{$}}
649 ; CHECK-NEXT:  end_loop{{$}}
650 ; CHECK-NEXT:  block   {{$}}
651 ; CHECK-NOT:   br_if
652 ; CHECK:       br_table   $pop{{[^,]+}}, 0, 3, 1, 2, 3
653 ; CHECK-NEXT:  .LBB{{[0-9]+}}_6:
654 ; CHECK-NEXT:  end_block{{$}}
655 ; CHECK-NEXT:  end_loop{{$}}
656 ; CHECK-NEXT:  return{{$}}
657 ; CHECK-NEXT:  .LBB{{[0-9]+}}_7:
658 ; CHECK-NEXT:  end_block{{$}}
659 ; CHECK:       br        0{{$}}
660 ; CHECK-NEXT:  .LBB{{[0-9]+}}_8:
661 ; CHECK-NEXT:  end_loop{{$}}
662 define void @test10() {
663 bb0:
664   br label %bb1
666 bb1:
667   %tmp = phi i32 [ 2, %bb0 ], [ 3, %bb3 ]
668   %tmp3 = phi i32 [ undef, %bb0 ], [ %tmp11, %bb3 ]
669   %tmp4 = icmp eq i32 %tmp3, 0
670   br i1 %tmp4, label %bb4, label %bb2
672 bb2:
673   br label %bb3
675 bb3:
676   %tmp11 = phi i32 [ 1, %bb5 ], [ 0, %bb2 ]
677   br label %bb1
679 bb4:
680   %tmp6 = phi i32 [ %tmp9, %bb5 ], [ 4, %bb1 ]
681   %tmp7 = phi i32 [ %tmp6, %bb5 ], [ %tmp, %bb1 ]
682   br label %bb5
684 bb5:
685   %tmp9 = phi i32 [ %tmp6, %bb5 ], [ %tmp7, %bb4 ]
686   switch i32 %tmp9, label %bb2 [
687     i32 0, label %bb5
688     i32 1, label %bb6
689     i32 3, label %bb4
690     i32 4, label %bb3
691   ]
693 bb6:
694   ret void
697 ; Test a CFG DAG with interesting merging.
699 ; CHECK-LABEL: test11:
700 ; CHECK:       block   {{$}}
701 ; CHECK-NEXT:  block   {{$}}
702 ; CHECK-NEXT:  block   {{$}}
703 ; CHECK-NEXT:  block   {{$}}
704 ; CHECK:       br_if        0, {{[^,]+}}{{$}}
705 ; CHECK-NOT:   block
706 ; CHECK:       block   {{$}}
707 ; CHECK-NEXT:  i32.const
708 ; CHECK-NEXT:  br_if        0, {{[^,]+}}{{$}}
709 ; CHECK-NOT:   block
710 ; CHECK:       br_if        2, {{[^,]+}}{{$}}
711 ; CHECK-NEXT:  .LBB{{[0-9]+}}_3:
712 ; CHECK-NEXT:  end_block{{$}}
713 ; CHECK-NOT:   block
714 ; CHECK:       return{{$}}
715 ; CHECK-NEXT:  .LBB{{[0-9]+}}_4:
716 ; CHECK-NEXT:  end_block{{$}}
717 ; CHECK-NOT:   block
718 ; CHECK:       br_if        1, {{[^,]+}}{{$}}
719 ; CHECK-NOT:   block
720 ; CHECK:       br_if        2, {{[^,]+}}{{$}}
721 ; CHECK-NEXT:  .LBB{{[0-9]+}}_6:
722 ; CHECK-NEXT:  end_block{{$}}
723 ; CHECK-NOT:   block
724 ; CHECK:       return{{$}}
725 ; CHECK-NEXT:  .LBB{{[0-9]+}}_7:
726 ; CHECK-NEXT:  end_block{{$}}
727 ; CHECK-NOT:   block
728 ; CHECK:       return{{$}}
729 ; CHECK-NEXT:  .LBB{{[0-9]+}}_8:
730 ; CHECK-NEXT:  end_block{{$}}
731 ; CHECK-NOT:   block
732 ; CHECK:       return{{$}}
733 define void @test11() {
734 bb0:
735   store volatile i32 0, i32* null
736   br i1 undef, label %bb1, label %bb4
737 bb1:
738   store volatile i32 1, i32* null
739   br i1 undef, label %bb3, label %bb2
740 bb2:
741   store volatile i32 2, i32* null
742   br i1 undef, label %bb3, label %bb7
743 bb3:
744   store volatile i32 3, i32* null
745   ret void
746 bb4:
747   store volatile i32 4, i32* null
748   br i1 undef, label %bb8, label %bb5
749 bb5:
750   store volatile i32 5, i32* null
751   br i1 undef, label %bb6, label %bb7
752 bb6:
753   store volatile i32 6, i32* null
754   ret void
755 bb7:
756   store volatile i32 7, i32* null
757   ret void
758 bb8:
759   store volatile i32 8, i32* null
760   ret void
763 ; CHECK-LABEL: test12:
764 ; CHECK:       .LBB{{[0-9]+}}_1:
765 ; CHECK-NEXT:  block   {{$}}
766 ; CHECK-NEXT:  loop    {{$}}
767 ; CHECK-NEXT:  block   {{$}}
768 ; CHECK-NEXT:  block   {{$}}
769 ; CHECK:       br_table  {{[^,]+}}, 1, 3, 3, 3, 1, 0{{$}}
770 ; CHECK-NEXT:  .LBB{{[0-9]+}}_2:
771 ; CHECK-NEXT:  end_block{{$}}
772 ; CHECK:       br_if     0, {{[^,]+}}{{$}}
773 ; CHECK:       br_if     2, {{[^,]+}}{{$}}
774 ; CHECK-NEXT:  .LBB{{[0-9]+}}_4:
775 ; CHECK-NEXT:  end_block{{$}}
776 ; CHECK:       br        0{{$}}
777 ; CHECK-NEXT:  .LBB{{[0-9]+}}_5:
778 ; CHECK-NEXT:  end_loop{{$}}
779 ; CHECK-NEXT:  end_block{{$}}
780 ; CHECK-NEXT:  return{{$}}
781 define void @test12(i8* %arg) {
783   br label %bb1
785 bb1:
786   %tmp = phi i32 [ 0, %bb ], [ %tmp5, %bb4 ]
787   %tmp2 = getelementptr i8, i8* %arg, i32 %tmp
788   %tmp3 = load i8, i8* %tmp2
789   switch i8 %tmp3, label %bb7 [
790     i8 42, label %bb4
791     i8 76, label %bb4
792     i8 108, label %bb4
793     i8 104, label %bb4
794   ]
796 bb4:
797   %tmp5 = add i32 %tmp, 1
798   br label %bb1
800 bb7:
801   ret void
804 ; A block can be "branched to" from another even if it is also reachable via
805 ; fallthrough from the other. This would normally be optimized away, so use
806 ; optnone to disable optimizations to test this case.
808 ; CHECK-LABEL: test13:
809 ; CHECK:       block   {{$}}
810 ; CHECK-NEXT:  block   {{$}}
811 ; CHECK:       br_if 0, $pop0{{$}}
812 ; CHECK:       block   {{$}}
813 ; CHECK:       br_if 0, $pop3{{$}}
814 ; CHECK:       .LBB{{[0-9]+}}_3:
815 ; CHECK-NEXT:  end_block{{$}}
816 ; CHECK:       br_if 1, $pop{{[0-9]+}}{{$}}
817 ; CHECK-NEXT:  br 1{{$}}
818 ; CHECK-NEXT:  .LBB{{[0-9]+}}_4:
819 ; CHECK-NEXT:  end_block{{$}}
820 ; CHECK-NEXT:  return{{$}}
821 ; CHECK-NEXT:  .LBB{{[0-9]+}}_5:
822 ; CHECK-NEXT:  end_block{{$}}
823 ; CHECK-NEXT:  unreachable{{$}}
824 define void @test13() noinline optnone {
826   br i1 undef, label %bb5, label %bb2
827 bb1:
828   unreachable
829 bb2:
830   br i1 undef, label %bb3, label %bb4
831 bb3:
832   br label %bb4
833 bb4:
834   %tmp = phi i1 [ false, %bb2 ], [ false, %bb3 ]
835   br i1 %tmp, label %bb1, label %bb1
836 bb5:
837   ret void
840 ; Test a case with a single-block loop that has another loop
841 ; as a successor. The end_loop for the first loop should go
842 ; before the loop for the second.
844 ; CHECK-LABEL: test14:
845 ; CHECK:      .LBB{{[0-9]+}}_1:{{$}}
846 ; CHECK-NEXT:     loop    {{$}}
847 ; CHECK-NEXT:     i32.const   $push0=, 0{{$}}
848 ; CHECK-NEXT:     br_if       0, $pop0{{$}}
849 ; CHECK-NEXT:     end_loop{{$}}
850 ; CHECK-NEXT: .LBB{{[0-9]+}}_3:{{$}}
851 ; CHECK-NEXT:     loop    {{$}}
852 ; CHECK-NEXT:     i32.const   $push1=, 0{{$}}
853 ; CHECK-NEXT:     br_if       0, $pop1{{$}}
854 ; CHECK-NEXT:     end_loop{{$}}
855 ; CHECK-NEXT:     return{{$}}
856 define void @test14() {
858   br label %bb1
860 bb1:
861   %tmp = bitcast i1 undef to i1
862   br i1 %tmp, label %bb3, label %bb1
864 bb3:
865   br label %bb4
867 bb4:
868   br i1 undef, label %bb7, label %bb48
870 bb7:
871   br i1 undef, label %bb12, label %bb12
873 bb12:
874   br i1 undef, label %bb17, label %bb17
876 bb17:
877   br i1 undef, label %bb22, label %bb22
879 bb22:
880   br i1 undef, label %bb27, label %bb27
882 bb27:
883   br i1 undef, label %bb30, label %bb30
885 bb30:
886   br i1 undef, label %bb35, label %bb35
888 bb35:
889   br i1 undef, label %bb38, label %bb38
891 bb38:
892   br i1 undef, label %bb48, label %bb48
894 bb48:
895   %tmp49 = bitcast i1 undef to i1
896   br i1 %tmp49, label %bb3, label %bb50
898 bb50:
899   ret void
902 ; Test that a block boundary which ends one block, begins another block, and
903 ; also begins a loop, has the markers placed in the correct order.
905 ; CHECK-LABEL: test15:
906 ; CHECK:        block
907 ; CHECK-NEXT:   block
908 ; CHECK:        br_if       0, $pop{{.*}}{{$}}
909 ; CHECK:        .LBB{{[0-9]+}}_2:
910 ; CHECK-NEXT:   block   {{$}}
911 ; CHECK-NEXT:   block   {{$}}
912 ; CHECK-NEXT:   loop    {{$}}
913 ; CHECK:        br_if       1, $pop{{.*}}{{$}}
914 ; CHECK:        br_if       0, ${{.*}}{{$}}
915 ; CHECK-NEXT:   br          2{{$}}
916 ; CHECK-NEXT:   .LBB{{[0-9]+}}_4:
917 ; CHECK-NEXT:   end_loop{{$}}
918 ; CHECK:        .LBB{{[0-9]+}}_5:
919 ; CHECK-NEXT:   end_block{{$}}
920 ; CHECK:        br_if       1, $pop{{.*}}{{$}}
921 ; CHECK:        return{{$}}
922 ; CHECK:        .LBB{{[0-9]+}}_7:
923 ; CHECK-NEXT:   end_block{{$}}
924 ; CHECK:        .LBB{{[0-9]+}}_8:
925 ; CHECK-NEXT:   end_block{{$}}
926 ; CHECK-NEXT:   return{{$}}
927 %0 = type { i8, i32 }
928 declare void @test15_callee0()
929 declare void @test15_callee1()
930 define void @test15() {
932   %tmp1 = icmp eq i8 1, 0
933   br i1 %tmp1, label %bb2, label %bb14
935 bb2:
936   %tmp3 = phi %0** [ %tmp6, %bb5 ], [ null, %bb ]
937   %tmp4 = icmp eq i32 0, 11
938   br i1 %tmp4, label %bb5, label %bb8
940 bb5:
941   %tmp = bitcast i8* null to %0**
942   %tmp6 = getelementptr %0*, %0** %tmp3, i32 1
943   %tmp7 = icmp eq %0** %tmp6, null
944   br i1 %tmp7, label %bb10, label %bb2
946 bb8:
947   %tmp9 = icmp eq %0** null, undef
948   br label %bb10
950 bb10:
951   %tmp11 = phi %0** [ null, %bb8 ], [ %tmp, %bb5 ]
952   %tmp12 = icmp eq %0** null, %tmp11
953   br i1 %tmp12, label %bb15, label %bb13
955 bb13:
956   call void @test15_callee0()
957   ret void
959 bb14:
960   call void @test15_callee1()
961   ret void
963 bb15:
964   ret void