1 # RUN: llc -mtriple=wasm32-unknown-unknown -run-pass wasm-fix-irreducible-control-flow %s -o - | FileCheck %s
3 # This tests if we correctly create at most 2 routing blocks per entry block,
4 # and also whether those routing blocks are generated in the correct place. If
5 # one of the predecessor is the layout predecessor of an entry, a routing block
6 # for the entry should be generated right after the layout predecessor.
9 target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
10 target triple = "wasm32-unknown-unknown"
12 define void @test0() {
28 - { reg: '$arguments' }
31 successors: %bb.1, %bb.2
33 %0:i32 = CONST_I32 100, implicit-def $arguments
34 BR_IF %bb.2, %0:i32, implicit-def $arguments
36 ; CHECK: BR_IF %bb.2, %0, implicit-def $arguments
40 successors: %bb.2, %bb.3
41 BR_IF %bb.3, %0:i32, implicit-def $arguments
43 ; CHECK: BR_IF %bb.7, %0, implicit-def $arguments
44 ; This falls through to bb.2, so we don't need an additional BR here
47 ; Routing block for entry0, when predecessor is outside the loop
48 ; This routing block is shared between the two predecessors: pred0 and pred1.
50 ; CHECK: %1:i32 = CONST_I32 0, implicit-def $arguments
51 ; CHECK: BR %bb.6, implicit-def $arguments
54 ; predecessors: %bb.0, %bb.1, %bb.1
56 BR %bb.3, implicit-def $arguments
58 ; CHECK: BR %bb.4, implicit-def $arguments
60 ; Routing block for entry1, when predecessor is inside the loop
62 ; CHECK: %1:i32 = CONST_I32 1, implicit-def $arguments
63 ; CHECK: BR %bb.6, implicit-def $arguments
66 ; predecessors: %bb.1, %bb.2
68 BR %bb.2, implicit-def $arguments
70 ; CHECK: BR %bb.8, implicit-def $arguments
74 ; CHECK: BR_TABLE_I32 %1, %bb.3, %bb.5, %bb.5, implicit-def $arguments
76 ; Routing block for entry1, when predecessor is outside the loop
78 ; CHECK: %1:i32 = CONST_I32 1, implicit-def $arguments
79 ; CHECK: BR %bb.6, implicit-def $arguments
81 ; Routing block for entry0, when predecessor is inside the loop
83 ; CHECK: %1:i32 = CONST_I32 0, implicit-def $arguments
84 ; CHECK: BR %bb.6, implicit-def $arguments