diff options
author | Alon Zakai <azakai@google.com> | 2024-10-17 12:49:43 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-10-17 12:49:43 -0700 |
commit | 6566329fecd36c8cd8e2ab29f89dafde0d2e9304 (patch) | |
tree | 87e722eb17ab96e3dfe2ac865b53e6bede8bb61d /test/lit/passes | |
parent | fd86eadb591576b82b0b564f95952b131979e91a (diff) | |
download | binaryen-6566329fecd36c8cd8e2ab29f89dafde0d2e9304.tar.gz binaryen-6566329fecd36c8cd8e2ab29f89dafde0d2e9304.tar.bz2 binaryen-6566329fecd36c8cd8e2ab29f89dafde0d2e9304.zip |
[EH][GC] Send a non-nullable exnref from TryTable (#7013)
When EH+GC are enabled then wasm has non-nullable types, and the
sent exnref should be non-nullable. In BinaryenIR we use the non-
nullable type all the time, which we also do for function references
and other things; we lower it if GC is not enabled to a nullable type
for the binary format (see `WasmBinaryWriter::writeType`, to which
comments were added in this PR). That is, this PR makes us handle
exnref the same as those other types.
A new test verifies that behavior. Various existing tests are updated
because ReFinalize will now use the more refined type, so this is
an optimization. It is also a bugfix as in #6987 we started to emit
the refined form in the fuzzer, and this PR makes us handle it
properly in validation and ReFinalization.
Diffstat (limited to 'test/lit/passes')
-rw-r--r-- | test/lit/passes/merge-blocks-eh.wast | 2 | ||||
-rw-r--r-- | test/lit/passes/translate-to-exnref.wast | 140 |
2 files changed, 71 insertions, 71 deletions
diff --git a/test/lit/passes/merge-blocks-eh.wast b/test/lit/passes/merge-blocks-eh.wast index e53f601fd..e56f536f4 100644 --- a/test/lit/passes/merge-blocks-eh.wast +++ b/test/lit/passes/merge-blocks-eh.wast @@ -100,7 +100,7 @@ ;; CHECK: (func $drop-block-try_catch_multi_partial (type $0) ;; CHECK-NEXT: (tuple.drop 2 - ;; CHECK-NEXT: (block $outer (type $1) (result i32 exnref) + ;; CHECK-NEXT: (block $outer (type $2) (result i32 (ref exn)) ;; CHECK-NEXT: (block $inner ;; CHECK-NEXT: (try_table (catch_ref $i32 $outer) (catch_all $inner) ;; CHECK-NEXT: (call $import) diff --git a/test/lit/passes/translate-to-exnref.wast b/test/lit/passes/translate-to-exnref.wast index abba6b06e..8bac0dc39 100644 --- a/test/lit/passes/translate-to-exnref.wast +++ b/test/lit/passes/translate-to-exnref.wast @@ -10,9 +10,9 @@ ;; CHECK: (type $2 (func (result i32))) - ;; CHECK: (type $3 (func (result i32 exnref))) + ;; CHECK: (type $3 (func (result i32 (ref exn)))) - ;; CHECK: (type $4 (func (result i32 i64 exnref))) + ;; CHECK: (type $4 (func (result i32 i64 (ref exn)))) ;; CHECK: (type $5 (func (param i32))) @@ -25,9 +25,9 @@ ;; STACKIR-OPT: (type $2 (func (result i32))) - ;; STACKIR-OPT: (type $3 (func (result i32 exnref))) + ;; STACKIR-OPT: (type $3 (func (result i32 (ref exn)))) - ;; STACKIR-OPT: (type $4 (func (result i32 i64 exnref))) + ;; STACKIR-OPT: (type $4 (func (result i32 i64 (ref exn)))) ;; STACKIR-OPT: (type $5 (func (param i32))) @@ -115,9 +115,9 @@ ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (block $outer0 ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch1 (result exnref) + ;; CHECK-NEXT: (block $catch1 (result (ref exn)) ;; CHECK-NEXT: (try_table (catch_ref $e-empty $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) ;; CHECK-NEXT: ) @@ -137,8 +137,8 @@ ;; STACKIR-OPT: (func $try-none-tag-none-with-rethrow (type $1) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: block $outer0 - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (result (ref exn)) ;; STACKIR-OPT-NEXT: try_table (catch_ref $e-empty $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: end @@ -220,12 +220,12 @@ ;; CHECK: (func $try-none-tag-single-with-rethrow (type $1) ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 i32) - ;; CHECK-NEXT: (local $2 (tuple i32 exnref)) + ;; CHECK-NEXT: (local $2 (tuple i32 (ref exn))) ;; CHECK-NEXT: (block $outer0 ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $2 - ;; CHECK-NEXT: (block $catch1 (type $3) (result i32 exnref) + ;; CHECK-NEXT: (block $catch1 (type $3) (result i32 (ref exn)) ;; CHECK-NEXT: (try_table (catch_ref $e-i32 $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) ;; CHECK-NEXT: ) @@ -260,10 +260,10 @@ ;; STACKIR-OPT: (func $try-none-tag-single-with-rethrow (type $1) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 i32) - ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 exnref)) + ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (type $3) (result i32 exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (type $3) (result i32 (ref exn)) ;; STACKIR-OPT-NEXT: try_table (catch_ref $e-i32 $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: end @@ -358,12 +358,12 @@ ;; CHECK: (func $try-none-tag-tuple-with-rethrow (type $1) ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 (tuple i32 i64)) - ;; CHECK-NEXT: (local $2 (tuple i32 i64 exnref)) + ;; CHECK-NEXT: (local $2 (tuple i32 i64 (ref exn))) ;; CHECK-NEXT: (block $outer0 ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $2 - ;; CHECK-NEXT: (block $catch1 (type $4) (result i32 i64 exnref) + ;; CHECK-NEXT: (block $catch1 (type $4) (result i32 i64 (ref exn)) ;; CHECK-NEXT: (try_table (catch_ref $e-i32-i64 $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) ;; CHECK-NEXT: ) @@ -403,10 +403,10 @@ ;; STACKIR-OPT: (func $try-none-tag-tuple-with-rethrow (type $1) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 (tuple i32 i64)) - ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64 exnref)) + ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (type $4) (result i32 i64 exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (type $4) (result i32 i64 (ref exn)) ;; STACKIR-OPT-NEXT: try_table (catch_ref $e-i32-i64 $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: end @@ -500,9 +500,9 @@ ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (block $outer0 (result i32) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch1 (result exnref) + ;; CHECK-NEXT: (block $catch1 (result (ref exn)) ;; CHECK-NEXT: (br $outer0 ;; CHECK-NEXT: (try_table (result i32) (catch_ref $e-empty $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) @@ -524,8 +524,8 @@ ;; STACKIR-OPT: (func $try-single-tag-none-with-rethrow (type $2) (result i32) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: block $outer0 (result i32) - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (result (ref exn)) ;; STACKIR-OPT-NEXT: try_table (result i32) (catch_ref $e-empty $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: i32.const 0 @@ -609,12 +609,12 @@ ;; CHECK: (func $try-single-tag-single-with-rethrow (type $2) (result i32) ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 i32) - ;; CHECK-NEXT: (local $2 (tuple i32 exnref)) + ;; CHECK-NEXT: (local $2 (tuple i32 (ref exn))) ;; CHECK-NEXT: (block $outer0 (result i32) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $2 - ;; CHECK-NEXT: (block $catch1 (type $3) (result i32 exnref) + ;; CHECK-NEXT: (block $catch1 (type $3) (result i32 (ref exn)) ;; CHECK-NEXT: (br $outer0 ;; CHECK-NEXT: (try_table (result i32) (catch_ref $e-i32 $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) @@ -653,10 +653,10 @@ ;; STACKIR-OPT: (func $try-single-tag-single-with-rethrow (type $2) (result i32) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 i32) - ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 exnref)) + ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 (result i32) - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (type $3) (result i32 exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (type $3) (result i32 (ref exn)) ;; STACKIR-OPT-NEXT: try_table (result i32) (catch_ref $e-i32 $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: i32.const 0 @@ -764,12 +764,12 @@ ;; CHECK: (func $try-single-tag-tuple-with-rethrow (type $2) (result i32) ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 (tuple i32 i64)) - ;; CHECK-NEXT: (local $2 (tuple i32 i64 exnref)) + ;; CHECK-NEXT: (local $2 (tuple i32 i64 (ref exn))) ;; CHECK-NEXT: (block $outer0 (result i32) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $2 - ;; CHECK-NEXT: (block $catch1 (type $4) (result i32 i64 exnref) + ;; CHECK-NEXT: (block $catch1 (type $4) (result i32 i64 (ref exn)) ;; CHECK-NEXT: (br $outer0 ;; CHECK-NEXT: (try_table (result i32) (catch_ref $e-i32-i64 $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) @@ -813,10 +813,10 @@ ;; STACKIR-OPT: (func $try-single-tag-tuple-with-rethrow (type $2) (result i32) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 (tuple i32 i64)) - ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64 exnref)) + ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 (result i32) - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (type $4) (result i32 i64 exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (type $4) (result i32 i64 (ref exn)) ;; STACKIR-OPT-NEXT: try_table (result i32) (catch_ref $e-i32-i64 $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: i32.const 0 @@ -937,9 +937,9 @@ ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (block $outer0 (type $0) (result i32 i64) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch1 (result exnref) + ;; CHECK-NEXT: (block $catch1 (result (ref exn)) ;; CHECK-NEXT: (br $outer0 ;; CHECK-NEXT: (try_table (type $0) (result i32 i64) (catch_ref $e-empty $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) @@ -964,8 +964,8 @@ ;; STACKIR-OPT: (func $try-tuple-tag-none-with-rethrow (type $0) (result i32 i64) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: block $outer0 (type $0) (result i32 i64) - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (result (ref exn)) ;; STACKIR-OPT-NEXT: try_table (type $0) (result i32 i64) (catch_ref $e-empty $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: i32.const 0 @@ -1078,12 +1078,12 @@ ;; CHECK: (func $try-tuple-tag-single-with-rethrow (type $0) (result i32 i64) ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 i32) - ;; CHECK-NEXT: (local $2 (tuple i32 exnref)) + ;; CHECK-NEXT: (local $2 (tuple i32 (ref exn))) ;; CHECK-NEXT: (block $outer0 (type $0) (result i32 i64) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $2 - ;; CHECK-NEXT: (block $catch1 (type $3) (result i32 exnref) + ;; CHECK-NEXT: (block $catch1 (type $3) (result i32 (ref exn)) ;; CHECK-NEXT: (br $outer0 ;; CHECK-NEXT: (try_table (type $0) (result i32 i64) (catch_ref $e-i32 $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) @@ -1125,10 +1125,10 @@ ;; STACKIR-OPT: (func $try-tuple-tag-single-with-rethrow (type $0) (result i32 i64) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 i32) - ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 exnref)) + ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 (type $0) (result i32 i64) - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (type $3) (result i32 exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (type $3) (result i32 (ref exn)) ;; STACKIR-OPT-NEXT: try_table (type $0) (result i32 i64) (catch_ref $e-i32 $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: i32.const 0 @@ -1247,12 +1247,12 @@ ;; CHECK: (func $try-tuple-tag-tuple-with-rethrow (type $0) (result i32 i64) ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 (tuple i32 i64)) - ;; CHECK-NEXT: (local $2 (tuple i32 i64 exnref)) + ;; CHECK-NEXT: (local $2 (tuple i32 i64 (ref exn))) ;; CHECK-NEXT: (block $outer0 (type $0) (result i32 i64) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all2 (result exnref) + ;; CHECK-NEXT: (block $catch_all2 (result (ref exn)) ;; CHECK-NEXT: (local.set $2 - ;; CHECK-NEXT: (block $catch1 (type $4) (result i32 i64 exnref) + ;; CHECK-NEXT: (block $catch1 (type $4) (result i32 i64 (ref exn)) ;; CHECK-NEXT: (br $outer0 ;; CHECK-NEXT: (try_table (type $0) (result i32 i64) (catch_ref $e-i32-i64 $catch1) (catch_all_ref $catch_all2) ;; CHECK-NEXT: (call $foo) @@ -1299,10 +1299,10 @@ ;; STACKIR-OPT: (func $try-tuple-tag-tuple-with-rethrow (type $0) (result i32 i64) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 (tuple i32 i64)) - ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64 exnref)) + ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 (type $0) (result i32 i64) - ;; STACKIR-OPT-NEXT: block $catch_all2 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (type $4) (result i32 i64 exnref) + ;; STACKIR-OPT-NEXT: block $catch_all2 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (type $4) (result i32 i64 (ref exn)) ;; STACKIR-OPT-NEXT: try_table (type $0) (result i32 i64) (catch_ref $e-i32-i64 $catch1) (catch_all_ref $catch_all2) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: i32.const 0 @@ -1375,17 +1375,17 @@ ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (local $1 i32) ;; CHECK-NEXT: (local $2 (tuple i32 i64)) - ;; CHECK-NEXT: (local $3 (tuple i32 exnref)) - ;; CHECK-NEXT: (local $4 (tuple i32 i64 exnref)) + ;; CHECK-NEXT: (local $3 (tuple i32 (ref exn))) + ;; CHECK-NEXT: (local $4 (tuple i32 i64 (ref exn))) ;; CHECK-NEXT: (block $outer0 ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all4 (result exnref) + ;; CHECK-NEXT: (block $catch_all4 (result (ref exn)) ;; CHECK-NEXT: (local.set $4 - ;; CHECK-NEXT: (block $catch3 (type $4) (result i32 i64 exnref) + ;; CHECK-NEXT: (block $catch3 (type $4) (result i32 i64 (ref exn)) ;; CHECK-NEXT: (local.set $3 - ;; CHECK-NEXT: (block $catch2 (type $3) (result i32 exnref) + ;; CHECK-NEXT: (block $catch2 (type $3) (result i32 (ref exn)) ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch1 (result exnref) + ;; CHECK-NEXT: (block $catch1 (result (ref exn)) ;; CHECK-NEXT: (try_table (catch_ref $e-empty $catch1) (catch_ref $e-i32 $catch2) (catch_ref $e-i32-i64 $catch3) (catch_all_ref $catch_all4) ;; CHECK-NEXT: (call $foo) ;; CHECK-NEXT: ) @@ -1451,13 +1451,13 @@ ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 i32) ;; STACKIR-OPT-NEXT: (local $2 (tuple i32 i64)) - ;; STACKIR-OPT-NEXT: (local $3 (tuple i32 exnref)) - ;; STACKIR-OPT-NEXT: (local $4 (tuple i32 i64 exnref)) + ;; STACKIR-OPT-NEXT: (local $3 (tuple i32 (ref exn))) + ;; STACKIR-OPT-NEXT: (local $4 (tuple i32 i64 (ref exn))) ;; STACKIR-OPT-NEXT: block $outer0 - ;; STACKIR-OPT-NEXT: block $catch_all4 (result exnref) - ;; STACKIR-OPT-NEXT: block $catch3 (type $4) (result i32 i64 exnref) - ;; STACKIR-OPT-NEXT: block $catch2 (type $3) (result i32 exnref) - ;; STACKIR-OPT-NEXT: block $catch1 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch_all4 (result (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch3 (type $4) (result i32 i64 (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch2 (type $3) (result i32 (ref exn)) + ;; STACKIR-OPT-NEXT: block $catch1 (result (ref exn)) ;; STACKIR-OPT-NEXT: try_table (catch_ref $e-empty $catch1) (catch_ref $e-i32 $catch2) (catch_ref $e-i32-i64 $catch3) (catch_all_ref $catch_all4) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: end @@ -1522,7 +1522,7 @@ ;; CHECK-NEXT: (local $1 exnref) ;; CHECK-NEXT: (block $outer3 ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch_all4 (result exnref) + ;; CHECK-NEXT: (block $catch_all4 (result (ref exn)) ;; CHECK-NEXT: (try_table (catch_all_ref $catch_all4) ;; CHECK-NEXT: (call $foo) ;; CHECK-NEXT: ) @@ -1531,7 +1531,7 @@ ;; CHECK-NEXT: ) ;; CHECK-NEXT: (block $outer0 ;; CHECK-NEXT: (local.set $1 - ;; CHECK-NEXT: (block $catch2 (result exnref) + ;; CHECK-NEXT: (block $catch2 (result (ref exn)) ;; CHECK-NEXT: (block $catch1 ;; CHECK-NEXT: (try_table (catch $e-empty $catch1) (catch_ref $e-empty $catch2) ;; CHECK-NEXT: (call $foo) @@ -1553,7 +1553,7 @@ ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: (local $1 exnref) ;; STACKIR-OPT-NEXT: block $outer3 - ;; STACKIR-OPT-NEXT: block $catch_all4 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch_all4 (result (ref exn)) ;; STACKIR-OPT-NEXT: try_table (catch_all_ref $catch_all4) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: end @@ -1561,7 +1561,7 @@ ;; STACKIR-OPT-NEXT: end ;; STACKIR-OPT-NEXT: local.set $0 ;; STACKIR-OPT-NEXT: block $outer0 - ;; STACKIR-OPT-NEXT: block $catch2 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch2 (result (ref exn)) ;; STACKIR-OPT-NEXT: block $catch1 ;; STACKIR-OPT-NEXT: try_table (catch $e-empty $catch1) (catch_ref $e-empty $catch2) ;; STACKIR-OPT-NEXT: call $foo @@ -2216,7 +2216,7 @@ ;; CHECK-NEXT: (local $0 exnref) ;; CHECK-NEXT: (block $outer2 ;; CHECK-NEXT: (local.set $0 - ;; CHECK-NEXT: (block $catch3 (result exnref) + ;; CHECK-NEXT: (block $catch3 (result (ref exn)) ;; CHECK-NEXT: (try_table (catch_ref $e-empty $catch3) ;; CHECK-NEXT: (call $foo) ;; CHECK-NEXT: ) @@ -2245,7 +2245,7 @@ ;; STACKIR-OPT: (func $try-catch-rethrow-with-inner-delegate (type $1) ;; STACKIR-OPT-NEXT: (local $0 exnref) ;; STACKIR-OPT-NEXT: block $outer2 - ;; STACKIR-OPT-NEXT: block $catch3 (result exnref) + ;; STACKIR-OPT-NEXT: block $catch3 (result (ref exn)) ;; STACKIR-OPT-NEXT: try_table (catch_ref $e-empty $catch3) ;; STACKIR-OPT-NEXT: call $foo ;; STACKIR-OPT-NEXT: end |