summaryrefslogtreecommitdiffstats
path: root/test/CodeGen/WebAssembly/switch.ll
diff options
context:
space:
mode:
Diffstat (limited to 'test/CodeGen/WebAssembly/switch.ll')
-rw-r--r--test/CodeGen/WebAssembly/switch.ll86
1 files changed, 43 insertions, 43 deletions
diff --git a/test/CodeGen/WebAssembly/switch.ll b/test/CodeGen/WebAssembly/switch.ll
index 7f6f6ef..3df5e7f 100644
--- a/test/CodeGen/WebAssembly/switch.ll
+++ b/test/CodeGen/WebAssembly/switch.ll
@@ -3,7 +3,7 @@
; Test switch instructions. Block placement is disabled because it reorders
; the blocks in a way that isn't interesting here.
-target datalayout = "e-p:32:32-i64:64-n32:64-S128"
+target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
target triple = "wasm32-unknown-unknown"
declare void @foo0()
@@ -14,27 +14,27 @@ declare void @foo4()
declare void @foo5()
; CHECK-LABEL: bar32:
-; CHECK: block BB0_8{{$}}
-; CHECK: block BB0_7{{$}}
-; CHECK: block BB0_6{{$}}
-; CHECK: block BB0_5{{$}}
-; CHECK: block BB0_4{{$}}
-; CHECK: block BB0_3{{$}}
-; CHECK: block BB0_2{{$}}
-; CHECK: tableswitch {{[^,]*}}, BB0_2, BB0_2, BB0_2, BB0_2, BB0_2, BB0_2, BB0_2, BB0_2, BB0_3, BB0_3, BB0_3, BB0_3, BB0_3, BB0_3, BB0_3, BB0_3, BB0_4, BB0_4, BB0_4, BB0_4, BB0_4, BB0_4, BB0_5, BB0_6, BB0_7{{$}}
-; CHECK: BB0_2:
-; CHECK: call foo0
-; CHECK: BB0_3:
-; CHECK: call foo1
-; CHECK: BB0_4:
-; CHECK: call foo2
-; CHECK: BB0_5:
-; CHECK: call foo3
-; CHECK: BB0_6:
-; CHECK: call foo4
-; CHECK: BB0_7:
-; CHECK: call foo5
-; CHECK: BB0_8:
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: tableswitch {{[^,]*}}, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 4, 5{{$}}
+; CHECK: .LBB0_2:
+; CHECK: call foo0@FUNCTION{{$}}
+; CHECK: .LBB0_3:
+; CHECK: call foo1@FUNCTION{{$}}
+; CHECK: .LBB0_4:
+; CHECK: call foo2@FUNCTION{{$}}
+; CHECK: .LBB0_5:
+; CHECK: call foo3@FUNCTION{{$}}
+; CHECK: .LBB0_6:
+; CHECK: call foo4@FUNCTION{{$}}
+; CHECK: .LBB0_7:
+; CHECK: call foo5@FUNCTION{{$}}
+; CHECK: .LBB0_8:
; CHECK: return{{$}}
define void @bar32(i32 %n) {
entry:
@@ -94,27 +94,27 @@ sw.epilog: ; preds = %entry, %sw.bb.5, %s
}
; CHECK-LABEL: bar64:
-; CHECK: block BB1_8{{$}}
-; CHECK: block BB1_7{{$}}
-; CHECK: block BB1_6{{$}}
-; CHECK: block BB1_5{{$}}
-; CHECK: block BB1_4{{$}}
-; CHECK: block BB1_3{{$}}
-; CHECK: block BB1_2{{$}}
-; CHECK: tableswitch {{[^,]*}}, BB1_2, BB1_2, BB1_2, BB1_2, BB1_2, BB1_2, BB1_2, BB1_2, BB1_3, BB1_3, BB1_3, BB1_3, BB1_3, BB1_3, BB1_3, BB1_3, BB1_4, BB1_4, BB1_4, BB1_4, BB1_4, BB1_4, BB1_5, BB1_6, BB1_7{{$}}
-; CHECK: BB1_2:
-; CHECK: call foo0
-; CHECK: BB1_3:
-; CHECK: call foo1
-; CHECK: BB1_4:
-; CHECK: call foo2
-; CHECK: BB1_5:
-; CHECK: call foo3
-; CHECK: BB1_6:
-; CHECK: call foo4
-; CHECK: BB1_7:
-; CHECK: call foo5
-; CHECK: BB1_8:
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: block{{$}}
+; CHECK: tableswitch {{[^,]*}}, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 4, 5{{$}}
+; CHECK: .LBB1_2:
+; CHECK: call foo0@FUNCTION{{$}}
+; CHECK: .LBB1_3:
+; CHECK: call foo1@FUNCTION{{$}}
+; CHECK: .LBB1_4:
+; CHECK: call foo2@FUNCTION{{$}}
+; CHECK: .LBB1_5:
+; CHECK: call foo3@FUNCTION{{$}}
+; CHECK: .LBB1_6:
+; CHECK: call foo4@FUNCTION{{$}}
+; CHECK: .LBB1_7:
+; CHECK: call foo5@FUNCTION{{$}}
+; CHECK: .LBB1_8:
; CHECK: return{{$}}
define void @bar64(i64 %n) {
entry:
OpenPOWER on IntegriCloud