diff options
author | Thomas Lively <tlively@google.com> | 2023-11-21 08:50:53 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-11-20 23:50:53 -0800 |
commit | cccc7a6a66b00ab79626afe02f259aa5290d479c (patch) | |
tree | 1f03896877a1d59ee9c7ae6c25194382f767e4c6 /test | |
parent | beb816be810caa0b32ab37986e7cae6f6cf11b1b (diff) | |
download | binaryen-cccc7a6a66b00ab79626afe02f259aa5290d479c.tar.gz binaryen-cccc7a6a66b00ab79626afe02f259aa5290d479c.tar.bz2 binaryen-cccc7a6a66b00ab79626afe02f259aa5290d479c.zip |
[Parser] Parse tags and throw (#6126)
Also fix the parser to correctly error if an imported item appears after a
non-imported item and make the corresponding fix to the test.
Diffstat (limited to 'test')
-rw-r--r-- | test/lit/wat-kitchen-sink.wast | 328 |
1 files changed, 193 insertions, 135 deletions
diff --git a/test/lit/wat-kitchen-sink.wast b/test/lit/wat-kitchen-sink.wast index 6498a6e31..c61f502ca 100644 --- a/test/lit/wat-kitchen-sink.wast +++ b/test/lit/wat-kitchen-sink.wast @@ -15,9 +15,9 @@ (rec ;; CHECK: (type $pair (struct (field (mut i32)) (field (mut i64)))) - ;; CHECK: (type $4 (func (result i32 i64))) + ;; CHECK: (type $4 (func (param i32 i64))) - ;; CHECK: (type $5 (func (param i32 i64))) + ;; CHECK: (type $5 (func (result i32 i64))) ;; CHECK: (type $a1 (array i64)) @@ -27,13 +27,15 @@ ;; CHECK: (type $many (sub (func (param i32 i64 f32 f64) (result anyref (ref func))))) - ;; CHECK: (type $a0 (array i32)) + ;; CHECK: (type $10 (func)) ;; CHECK: (type $11 (func (param i32))) - ;; CHECK: (type $12 (func (param i32 i32 i32))) + ;; CHECK: (type $a0 (array i32)) + + ;; CHECK: (type $13 (func (param i32 i32 i32))) - ;; CHECK: (type $13 (func (param v128 i32) (result v128))) + ;; CHECK: (type $14 (func (param v128 i32) (result v128))) ;; CHECK: (rec ;; CHECK-NEXT: (type $s0 (struct )) @@ -48,73 +50,73 @@ ;; CHECK: (type $packed-i16 (array (mut i16))) - ;; CHECK: (type $18 (func (param i32 i64) (result f32))) + ;; CHECK: (type $19 (func (param i32 i64) (result f32))) - ;; CHECK: (type $19 (func (param i32 i32))) + ;; CHECK: (type $20 (func (param i32 i32))) - ;; CHECK: (type $20 (func (param i32 i32 f64 f64))) + ;; CHECK: (type $21 (func (param i32 i32 f64 f64))) - ;; CHECK: (type $21 (func (param i64))) + ;; CHECK: (type $22 (func (param i64))) - ;; CHECK: (type $22 (func (param v128) (result i32))) + ;; CHECK: (type $23 (func (param v128) (result i32))) - ;; CHECK: (type $23 (func (param v128 v128) (result v128))) + ;; CHECK: (type $24 (func (param v128 v128) (result v128))) - ;; CHECK: (type $24 (func (param v128 v128 v128) (result v128))) + ;; CHECK: (type $25 (func (param v128 v128 v128) (result v128))) - ;; CHECK: (type $25 (func (param i32 i64 v128))) + ;; CHECK: (type $26 (func (param i32 i64 v128))) - ;; CHECK: (type $26 (func (param i32 i32 i64 i64))) + ;; CHECK: (type $27 (func (param i32 i32 i64 i64))) - ;; CHECK: (type $27 (func (param i32) (result i32))) + ;; CHECK: (type $28 (func (param i32) (result i32))) - ;; CHECK: (type $28 (func (param i32 i64) (result i32 i64))) + ;; CHECK: (type $29 (func (param i32 i64) (result i32 i64))) - ;; CHECK: (type $29 (func (param i64) (result i32 i64))) + ;; CHECK: (type $30 (func (param i64) (result i32 i64))) - ;; CHECK: (type $30 (func (param i32) (result i32 i64))) + ;; CHECK: (type $31 (func (param i32) (result i32 i64))) - ;; CHECK: (type $31 (func (param anyref) (result i32))) + ;; CHECK: (type $32 (func (param anyref) (result i32))) - ;; CHECK: (type $32 (func (param eqref eqref) (result i32))) + ;; CHECK: (type $33 (func (param eqref eqref) (result i32))) - ;; CHECK: (type $33 (func (param i32) (result i31ref))) + ;; CHECK: (type $34 (func (param i32) (result i31ref))) - ;; CHECK: (type $34 (func (param i31ref))) + ;; CHECK: (type $35 (func (param i31ref))) - ;; CHECK: (type $35 (func (param i32 i64) (result (ref $pair)))) + ;; CHECK: (type $36 (func (param i32 i64) (result (ref $pair)))) - ;; CHECK: (type $36 (func (result (ref $pair)))) + ;; CHECK: (type $37 (func (result (ref $pair)))) - ;; CHECK: (type $37 (func (param (ref $pair)) (result i32))) + ;; CHECK: (type $38 (func (param (ref $pair)) (result i32))) - ;; CHECK: (type $38 (func (param (ref $pair)) (result i64))) + ;; CHECK: (type $39 (func (param (ref $pair)) (result i64))) - ;; CHECK: (type $39 (func (param (ref $pair) i32))) + ;; CHECK: (type $40 (func (param (ref $pair) i32))) - ;; CHECK: (type $40 (func (param (ref $pair) i64))) + ;; CHECK: (type $41 (func (param (ref $pair) i64))) - ;; CHECK: (type $41 (func (param i64 i32) (result (ref $a1)))) + ;; CHECK: (type $42 (func (param i64 i32) (result (ref $a1)))) - ;; CHECK: (type $42 (func (param i32) (result (ref $a1)))) + ;; CHECK: (type $43 (func (param i32) (result (ref $a1)))) - ;; CHECK: (type $43 (func (param i32 i32) (result (ref $a1)))) + ;; CHECK: (type $44 (func (param i32 i32) (result (ref $a1)))) - ;; CHECK: (type $44 (func (param (ref $a1) i32) (result i64))) + ;; CHECK: (type $45 (func (param (ref $a1) i32) (result i64))) - ;; CHECK: (type $45 (func (param (ref $packed-i8) i32) (result i32))) + ;; CHECK: (type $46 (func (param (ref $packed-i8) i32) (result i32))) - ;; CHECK: (type $46 (func (param (ref $packed-i16) i32) (result i32))) + ;; CHECK: (type $47 (func (param (ref $packed-i16) i32) (result i32))) - ;; CHECK: (type $47 (func (param (ref $a2) i32 f32))) + ;; CHECK: (type $48 (func (param (ref $a2) i32 f32))) - ;; CHECK: (type $48 (func (param arrayref) (result i32))) + ;; CHECK: (type $49 (func (param arrayref) (result i32))) - ;; CHECK: (type $49 (func (param (ref $a2) i32 (ref $a2) i32 i32))) + ;; CHECK: (type $50 (func (param (ref $a2) i32 (ref $a2) i32 i32))) - ;; CHECK: (type $50 (func (param (ref $a2) i32 f32 i32))) + ;; CHECK: (type $51 (func (param (ref $a2) i32 f32 i32))) - ;; CHECK: (type $51 (func (param externref))) + ;; CHECK: (type $52 (func (param externref))) ;; CHECK: (type $s2 (struct (field i32))) (type $s2 (struct i32)) @@ -156,16 +158,27 @@ ;; CHECK: (type $submany (sub final $many (func (param i32 i64 f32 f64) (result anyref (ref func))))) (type $submany (sub $many (func (param i32 i64 f32 f64) (result anyref (ref func))))) - ;; globals + ;; imported globals (global $g1 (export "g1") (export "g1.1") (import "mod" "g1") i32) (global $g2 (import "mod" "g2") (mut i64)) (global (import "" "g3") (ref 0)) (global (import "mod" "") (ref null $many)) + ;; imported memories + (memory (export "mem") (export "mem2") (import "" "mem") 0) + + ;; imported functions + (func (export "f5.0") (export "f5.1") (import "mod" "f5")) + + ;; imported tags + (tag $imported (export "t0.0") (export "t0.1") (import "mod" "t0") (param i32 i64)) + (tag (import "mod" "t1")) + + ;; globals (global (mut i32) i32.const 0) - ;; CHECK: (type $62 (func (param (ref $s0) (ref $s1) (ref $s2) (ref $s3) (ref $s4) (ref $s5) (ref $s6) (ref $s7) (ref $s8) (ref $a0) (ref $a1) (ref $a2) (ref $a3) (ref $subvoid) (ref $submany)))) + ;; CHECK: (type $63 (func (param (ref $s0) (ref $s1) (ref $s2) (ref $s3) (ref $s4) (ref $s5) (ref $s6) (ref $s7) (ref $s8) (ref $a0) (ref $a1) (ref $a2) (ref $a3) (ref $subvoid) (ref $submany)))) - ;; CHECK: (import "" "mem" (memory $mimport$1 0)) + ;; CHECK: (import "" "mem" (memory $mimport$0 0)) ;; CHECK: (import "mod" "g1" (global $g1 i32)) @@ -175,7 +188,11 @@ ;; CHECK: (import "mod" "" (global $gimport$1 (ref null $many))) - ;; CHECK: (import "mod" "f5" (func $fimport$1 (type $void))) + ;; CHECK: (import "mod" "f5" (func $fimport$0 (type $void))) + + ;; CHECK: (import "mod" "t0" (tag $imported (param i32 i64))) + + ;; CHECK: (import "mod" "t1" (tag $timport$0)) ;; CHECK: (global $2 (mut i32) (i32.const 0)) @@ -186,13 +203,14 @@ ;; CHECK: (memory $mem (shared 1 1)) (memory $mem 1 1 shared) (memory 0 1 shared) - ;; CHECK: (memory $0 (shared 0 1)) + ;; CHECK: (memory $1 (shared 0 1)) ;; CHECK: (memory $mem-i32 0 1) (memory $mem-i32 i32 0 1) + ;; CHECK: (memory $mem-i64 i64 2) (memory $mem-i64 i64 2) - (memory (export "mem") (export "mem2") (import "" "mem") 0) + ;; CHECK: (memory $mem-init 1 1) (memory $mem-init (data "hello inline data")) @@ -204,36 +222,58 @@ ;; CHECK: (data $passive "hello again") (data $passive "hello" " " "again") + ;; CHECK: (data $active (i32.const 0) "active hello") (data $active (offset i32.const 0) "active hello" "" "") + ;; CHECK: (data $active2 (i32.const 1) "active again!") (data $active2 (offset (i32.const 1)) "" "active again" "!") - ;; CHECK: (data $active3 (i32.const 42) "active abbreviated") + + ;; CHECK: (data $active3 (memory $mem) (i32.const 42) "active abbreviated") (data $active3 (memory $mem) (i32.const 42) "" "active abbreviated" "") + ;; CHECK: (data $active4 (memory $mem-i32) (i32.const 16) "") (data $active4 (memory $mem-i32) (i32.const 16) "") - (data (memory 3) (offset i64.const 0) "64-bit") - ;; functions - (func) + (data (memory 4) (offset i64.const 0) "64-bit") + ;; tags + (tag) ;; CHECK: (data $1 (memory $mem-i64) (i64.const 0) "64-bit") ;; CHECK: (elem declare func $ref-func) + ;; CHECK: (tag $1) + + ;; CHECK: (tag $empty) + (tag $empty) + + ;; CHECK: (tag $tag-i32 (param i32)) + (tag $tag-i32 (param $x i32)) + + ;; CHECK: (tag $tag-pair (param i32 i64)) + (tag $tag-pair (param i32 i64)) + + ;; functions + (func) + ;; CHECK: (export "g1" (global $g1)) ;; CHECK: (export "g1.1" (global $g1)) - ;; CHECK: (export "mem" (memory $mimport$1)) + ;; CHECK: (export "mem" (memory $mimport$0)) + + ;; CHECK: (export "mem2" (memory $mimport$0)) - ;; CHECK: (export "mem2" (memory $mimport$1)) + ;; CHECK: (export "f5.0" (func $fimport$0)) - ;; CHECK: (export "f5.0" (func $fimport$1)) + ;; CHECK: (export "f5.1" (func $fimport$0)) - ;; CHECK: (export "f5.1" (func $fimport$1)) + ;; CHECK: (export "t0.0" (tag $imported)) - ;; CHECK: (func $0 (type $void) + ;; CHECK: (export "t0.1" (tag $imported)) + + ;; CHECK: (func $1 (type $void) ;; CHECK-NEXT: (nop) ;; CHECK-NEXT: ) @@ -258,7 +298,6 @@ ;; CHECK-NEXT: (nop) ;; CHECK-NEXT: ) (func $f4 (type 17) (local i32 i64) (local $l f32)) - (func (export "f5.0") (export "f5.1") (import "mod" "f5")) ;; CHECK: (func $nop-skate (type $void) ;; CHECK-NEXT: (nop) @@ -685,7 +724,7 @@ drop ) - ;; CHECK: (func $locals (type $19) (param $0 i32) (param $x i32) + ;; CHECK: (func $locals (type $20) (param $0 i32) (param $x i32) ;; CHECK-NEXT: (local $2 i32) ;; CHECK-NEXT: (local $y i32) ;; CHECK-NEXT: (drop @@ -1616,8 +1655,8 @@ br 0 ) - ;; CHECK: (func $br-multivalue (type $4) (result i32 i64) - ;; CHECK-NEXT: (block $label (type $4) (result i32 i64) + ;; CHECK: (func $br-multivalue (type $5) (result i32 i64) + ;; CHECK-NEXT: (block $label (type $5) (result i32 i64) ;; CHECK-NEXT: (br $label ;; CHECK-NEXT: (tuple.make ;; CHECK-NEXT: (i32.const 0) @@ -1632,9 +1671,9 @@ br 0 ) - ;; CHECK: (func $br-multivalue-drop (type $4) (result i32 i64) - ;; CHECK-NEXT: (block $label (type $4) (result i32 i64) - ;; CHECK-NEXT: (block (type $4) (result i32 i64) + ;; CHECK: (func $br-multivalue-drop (type $5) (result i32 i64) + ;; CHECK-NEXT: (block $label (type $5) (result i32 i64) + ;; CHECK-NEXT: (block (type $5) (result i32 i64) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (f32.const 0) ;; CHECK-NEXT: ) @@ -1738,9 +1777,9 @@ end ) - ;; CHECK: (func $br-table-multivalue (type $4) (result i32 i64) - ;; CHECK-NEXT: (block $a (type $4) (result i32 i64) - ;; CHECK-NEXT: (block $b (type $4) (result i32 i64) + ;; CHECK: (func $br-table-multivalue (type $5) (result i32 i64) + ;; CHECK-NEXT: (block $a (type $5) (result i32 i64) + ;; CHECK-NEXT: (block $b (type $5) (result i32 i64) ;; CHECK-NEXT: (br_table $a $b ;; CHECK-NEXT: (tuple.make ;; CHECK-NEXT: (i32.const 42) @@ -1763,7 +1802,7 @@ ) - ;; CHECK: (func $binary (type $20) (param $0 i32) (param $1 i32) (param $2 f64) (param $3 f64) + ;; CHECK: (func $binary (type $21) (param $0 i32) (param $1 i32) (param $2 f64) (param $3 f64) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (i32.add ;; CHECK-NEXT: (local.get $0) @@ -1788,7 +1827,7 @@ drop ) - ;; CHECK: (func $unary (type $21) (param $0 i64) + ;; CHECK: (func $unary (type $22) (param $0 i64) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (i64.eqz ;; CHECK-NEXT: (local.get $0) @@ -1801,7 +1840,7 @@ drop ) - ;; CHECK: (func $select (type $12) (param $0 i32) (param $1 i32) (param $2 i32) + ;; CHECK: (func $select (type $13) (param $0 i32) (param $1 i32) (param $2 i32) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (select ;; CHECK-NEXT: (local.get $0) @@ -1856,10 +1895,10 @@ ;; CHECK: (func $memory-size (type $void) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (memory.size $mem) + ;; CHECK-NEXT: (memory.size $mimport$0) ;; CHECK-NEXT: ) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (memory.size $0) + ;; CHECK-NEXT: (memory.size $mem) ;; CHECK-NEXT: ) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (memory.size $mem-i64) @@ -1874,14 +1913,14 @@ drop ) - ;; CHECK: (func $memory-grow (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $memory-grow (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (memory.grow $mem + ;; CHECK-NEXT: (memory.grow $mimport$0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (memory.grow $0 + ;; CHECK-NEXT: (memory.grow $mem ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) @@ -1913,14 +1952,14 @@ global.set 4 ) - ;; CHECK: (func $load (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $load (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (i32.load $mem offset=42 + ;; CHECK-NEXT: (i32.load $mimport$0 offset=42 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (i64.load8_s $0 + ;; CHECK-NEXT: (i64.load8_s $mem ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) @@ -1942,12 +1981,12 @@ drop ) - ;; CHECK: (func $store (type $5) (param $0 i32) (param $1 i64) - ;; CHECK-NEXT: (i32.store $mem offset=42 align=1 + ;; CHECK: (func $store (type $4) (param $0 i32) (param $1 i64) + ;; CHECK-NEXT: (i32.store $mimport$0 offset=42 align=1 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i32.const 0) ;; CHECK-NEXT: ) - ;; CHECK-NEXT: (i64.atomic.store8 $0 + ;; CHECK-NEXT: (i64.atomic.store8 $mem ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i64.const 1) ;; CHECK-NEXT: ) @@ -1968,9 +2007,9 @@ f32.store $mem-i64 ) - ;; CHECK: (func $atomic-rmw (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $atomic-rmw (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (i32.atomic.rmw16.add_u $mem + ;; CHECK-NEXT: (i32.atomic.rmw16.add_u $mimport$0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i32.const 1) ;; CHECK-NEXT: ) @@ -1993,7 +2032,7 @@ drop ) - ;; CHECK: (func $atomic-cmpxchg (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $atomic-cmpxchg (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (i32.atomic.rmw8.cmpxchg_u $mem ;; CHECK-NEXT: (local.get $0) @@ -2013,18 +2052,18 @@ local.get 0 i32.const 1 i32.const 2 - i32.atomic.rmw8.cmpxchg_u 0 align=1 + i32.atomic.rmw8.cmpxchg_u 1 align=1 drop local.get 1 i64.const 3 i64.const 4 - i64.atomic.rmw32.cmpxchg_u 3 offset=16 + i64.atomic.rmw32.cmpxchg_u 4 offset=16 drop ) - ;; CHECK: (func $atomic-wait (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $atomic-wait (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (memory.atomic.wait32 $mem + ;; CHECK-NEXT: (memory.atomic.wait32 $mimport$0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i32.const 1) ;; CHECK-NEXT: (i64.const 2) @@ -2051,9 +2090,9 @@ drop ) - ;; CHECK: (func $atomic-notify (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $atomic-notify (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (memory.atomic.notify $mem offset=8 + ;; CHECK-NEXT: (memory.atomic.notify $mimport$0 offset=8 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i32.const 0) ;; CHECK-NEXT: ) @@ -2083,7 +2122,7 @@ atomic.fence ) - ;; CHECK: (func $simd-extract (type $22) (param $0 v128) (result i32) + ;; CHECK: (func $simd-extract (type $23) (param $0 v128) (result i32) ;; CHECK-NEXT: (i32x4.extract_lane 3 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2093,7 +2132,7 @@ i32x4.extract_lane 3 ) - ;; CHECK: (func $simd-replace (type $13) (param $0 v128) (param $1 i32) (result v128) + ;; CHECK: (func $simd-replace (type $14) (param $0 v128) (param $1 i32) (result v128) ;; CHECK-NEXT: (i32x4.replace_lane 2 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2105,7 +2144,7 @@ i32x4.replace_lane 2 ) - ;; CHECK: (func $simd-shuffle (type $23) (param $0 v128) (param $1 v128) (result v128) + ;; CHECK: (func $simd-shuffle (type $24) (param $0 v128) (param $1 v128) (result v128) ;; CHECK-NEXT: (i8x16.shuffle 0 1 2 3 4 5 6 7 16 17 18 19 20 21 22 23 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2117,7 +2156,7 @@ i8x16.shuffle 0 1 2 3 4 5 6 7 16 17 18 19 20 21 22 23 ) - ;; CHECK: (func $simd-ternary (type $24) (param $0 v128) (param $1 v128) (param $2 v128) (result v128) + ;; CHECK: (func $simd-ternary (type $25) (param $0 v128) (param $1 v128) (param $2 v128) (result v128) ;; CHECK-NEXT: (v128.bitselect ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2131,7 +2170,7 @@ v128.bitselect ) - ;; CHECK: (func $simd-shift (type $13) (param $0 v128) (param $1 i32) (result v128) + ;; CHECK: (func $simd-shift (type $14) (param $0 v128) (param $1 i32) (result v128) ;; CHECK-NEXT: (i8x16.shl ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2143,9 +2182,9 @@ i8x16.shl ) - ;; CHECK: (func $simd-load (type $5) (param $0 i32) (param $1 i64) + ;; CHECK: (func $simd-load (type $4) (param $0 i32) (param $1 i64) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (v128.load8x8_s $mem offset=8 + ;; CHECK-NEXT: (v128.load8x8_s $mimport$0 offset=8 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) @@ -2164,9 +2203,9 @@ drop ) - ;; CHECK: (func $simd-load-store-lane (type $25) (param $0 i32) (param $1 i64) (param $2 v128) + ;; CHECK: (func $simd-load-store-lane (type $26) (param $0 i32) (param $1 i64) (param $2 v128) ;; CHECK-NEXT: (drop - ;; CHECK-NEXT: (v128.load16_lane $mem 7 + ;; CHECK-NEXT: (v128.load16_lane $mimport$0 7 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $2) ;; CHECK-NEXT: ) @@ -2183,10 +2222,10 @@ drop local.get 1 local.get 2 - v128.store64_lane 3 align=4 0 + v128.store64_lane 4 align=4 0 ) - ;; CHECK: (func $memory-init (type $12) (param $0 i32) (param $1 i32) (param $2 i32) + ;; CHECK: (func $memory-init (type $13) (param $0 i32) (param $1 i32) (param $2 i32) ;; CHECK-NEXT: (memory.init $mem-i32 $passive ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2197,7 +2236,7 @@ ;; CHECK-NEXT: (local.get $1) ;; CHECK-NEXT: (local.get $2) ;; CHECK-NEXT: ) - ;; CHECK-NEXT: (memory.init $mem $implicit-data + ;; CHECK-NEXT: (memory.init $mimport$0 $implicit-data ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) ;; CHECK-NEXT: (local.get $2) @@ -2211,7 +2250,7 @@ i64.const 0 local.get 1 local.get 2 - memory.init 3 1 + memory.init 4 1 local.get 0 local.get 1 local.get 2 @@ -2227,8 +2266,8 @@ data.drop $passive ) - ;; CHECK: (func $memory-copy (type $26) (param $0 i32) (param $1 i32) (param $2 i64) (param $3 i64) - ;; CHECK-NEXT: (memory.copy $mem $mem + ;; CHECK: (func $memory-copy (type $27) (param $0 i32) (param $1 i32) (param $2 i64) (param $3 i64) + ;; CHECK-NEXT: (memory.copy $mimport$0 $mimport$0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) ;; CHECK-NEXT: (i32.const 2) @@ -2252,20 +2291,20 @@ local.get 0 local.get 1 i32.const 3 - memory.copy 0 $mem-i32 + memory.copy 1 $mem-i32 local.get 2 local.get 3 i64.const 4 - memory.copy $mem-i64 3 + memory.copy $mem-i64 4 ) - ;; CHECK: (func $memory-fill (type $5) (param $0 i32) (param $1 i64) - ;; CHECK-NEXT: (memory.fill $mem + ;; CHECK: (func $memory-fill (type $4) (param $0 i32) (param $1 i64) + ;; CHECK-NEXT: (memory.fill $mimport$0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i32.const 1) ;; CHECK-NEXT: (i32.const 2) ;; CHECK-NEXT: ) - ;; CHECK-NEXT: (memory.fill $mem + ;; CHECK-NEXT: (memory.fill $mimport$0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (i32.const 3) ;; CHECK-NEXT: (i32.const 4) @@ -2298,7 +2337,7 @@ return ) - ;; CHECK: (func $return-one (type $27) (param $0 i32) (result i32) + ;; CHECK: (func $return-one (type $28) (param $0 i32) (result i32) ;; CHECK-NEXT: (return ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2308,7 +2347,7 @@ return ) - ;; CHECK: (func $return-two (type $28) (param $0 i32) (param $1 i64) (result i32 i64) + ;; CHECK: (func $return-two (type $29) (param $0 i32) (param $1 i64) (result i32 i64) ;; CHECK-NEXT: (return ;; CHECK-NEXT: (tuple.make ;; CHECK-NEXT: (local.get $0) @@ -2322,7 +2361,7 @@ return ) - ;; CHECK: (func $return-two-first-unreachable (type $29) (param $0 i64) (result i32 i64) + ;; CHECK: (func $return-two-first-unreachable (type $30) (param $0 i64) (result i32 i64) ;; CHECK-NEXT: (return ;; CHECK-NEXT: (tuple.make ;; CHECK-NEXT: (unreachable) @@ -2336,7 +2375,7 @@ return ) - ;; CHECK: (func $return-two-second-unreachable (type $30) (param $0 i32) (result i32 i64) + ;; CHECK: (func $return-two-second-unreachable (type $31) (param $0 i32) (result i32 i64) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2353,7 +2392,7 @@ return ) - ;; CHECK: (func $ref-is-null (type $31) (param $0 anyref) (result i32) + ;; CHECK: (func $ref-is-null (type $32) (param $0 anyref) (result i32) ;; CHECK-NEXT: (ref.is_null ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2378,7 +2417,26 @@ drop ) - ;; CHECK: (func $ref-eq (type $32) (param $0 eqref) (param $1 eqref) (result i32) + ;; CHECK: (func $throw (type $void) + ;; CHECK-NEXT: (throw $1) + ;; CHECK-NEXT: (throw $tag-i32 + ;; CHECK-NEXT: (i32.const 0) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: (throw $tag-pair + ;; CHECK-NEXT: (i32.const 1) + ;; CHECK-NEXT: (i64.const 2) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + (func $throw + throw 2 + i32.const 0 + throw $tag-i32 + i32.const 1 + i64.const 2 + throw $tag-pair + ) + + ;; CHECK: (func $ref-eq (type $33) (param $0 eqref) (param $1 eqref) (result i32) ;; CHECK-NEXT: (ref.eq ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2390,7 +2448,7 @@ ref.eq ) - ;; CHECK: (func $i31-new (type $33) (param $0 i32) (result i31ref) + ;; CHECK: (func $i31-new (type $34) (param $0 i32) (result i31ref) ;; CHECK-NEXT: (ref.i31 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2400,7 +2458,7 @@ ref.i31 ) - ;; CHECK: (func $i31-get (type $34) (param $0 i31ref) + ;; CHECK: (func $i31-get (type $35) (param $0 i31ref) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (i31.get_s ;; CHECK-NEXT: (local.get $0) @@ -2625,7 +2683,7 @@ drop ) - ;; CHECK: (func $struct-new (type $35) (param $0 i32) (param $1 i64) (result (ref $pair)) + ;; CHECK: (func $struct-new (type $36) (param $0 i32) (param $1 i64) (result (ref $pair)) ;; CHECK-NEXT: (struct.new $pair ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2637,14 +2695,14 @@ struct.new $pair ) - ;; CHECK: (func $struct-new-default (type $36) (result (ref $pair)) + ;; CHECK: (func $struct-new-default (type $37) (result (ref $pair)) ;; CHECK-NEXT: (struct.new_default $pair) ;; CHECK-NEXT: ) (func $struct-new-default (result (ref $pair)) struct.new_default 14 ) - ;; CHECK: (func $struct-get-0 (type $37) (param $0 (ref $pair)) (result i32) + ;; CHECK: (func $struct-get-0 (type $38) (param $0 (ref $pair)) (result i32) ;; CHECK-NEXT: (struct.get $pair 0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2654,7 +2712,7 @@ struct.get 14 0 ) - ;; CHECK: (func $struct-get-1 (type $38) (param $0 (ref $pair)) (result i64) + ;; CHECK: (func $struct-get-1 (type $39) (param $0 (ref $pair)) (result i64) ;; CHECK-NEXT: (struct.get $pair 1 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2664,7 +2722,7 @@ struct.get $pair 1 ) - ;; CHECK: (func $struct-set-0 (type $39) (param $0 (ref $pair)) (param $1 i32) + ;; CHECK: (func $struct-set-0 (type $40) (param $0 (ref $pair)) (param $1 i32) ;; CHECK-NEXT: (struct.set $pair 0 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2676,7 +2734,7 @@ struct.set $pair 0 ) - ;; CHECK: (func $struct-set-1 (type $40) (param $0 (ref $pair)) (param $1 i64) + ;; CHECK: (func $struct-set-1 (type $41) (param $0 (ref $pair)) (param $1 i64) ;; CHECK-NEXT: (struct.set $pair 1 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2688,7 +2746,7 @@ struct.set 14 1 ) - ;; CHECK: (func $array-new (type $41) (param $0 i64) (param $1 i32) (result (ref $a1)) + ;; CHECK: (func $array-new (type $42) (param $0 i64) (param $1 i32) (result (ref $a1)) ;; CHECK-NEXT: (array.new $a1 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2700,7 +2758,7 @@ array.new $a1 ) - ;; CHECK: (func $array-new-default (type $42) (param $0 i32) (result (ref $a1)) + ;; CHECK: (func $array-new-default (type $43) (param $0 i32) (result (ref $a1)) ;; CHECK-NEXT: (array.new_default $a1 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2710,7 +2768,7 @@ array.new_default 11 ) - ;; CHECK: (func $array-new-data (type $43) (param $0 i32) (param $1 i32) (result (ref $a1)) + ;; CHECK: (func $array-new-data (type $44) (param $0 i32) (param $1 i32) (result (ref $a1)) ;; CHECK-NEXT: (array.new_data $a1 $implicit-data ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2744,7 +2802,7 @@ drop ) - ;; CHECK: (func $array-get (type $44) (param $0 (ref $a1)) (param $1 i32) (result i64) + ;; CHECK: (func $array-get (type $45) (param $0 (ref $a1)) (param $1 i32) (result i64) ;; CHECK-NEXT: (array.get $a1 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2756,7 +2814,7 @@ array.get $a1 ) - ;; CHECK: (func $array-get-s (type $45) (param $0 (ref $packed-i8)) (param $1 i32) (result i32) + ;; CHECK: (func $array-get-s (type $46) (param $0 (ref $packed-i8)) (param $1 i32) (result i32) ;; CHECK-NEXT: (array.get_s $packed-i8 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2768,7 +2826,7 @@ array.get_s 15 ) - ;; CHECK: (func $array-get-u (type $46) (param $0 (ref $packed-i16)) (param $1 i32) (result i32) + ;; CHECK: (func $array-get-u (type $47) (param $0 (ref $packed-i16)) (param $1 i32) (result i32) ;; CHECK-NEXT: (array.get_u $packed-i16 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2780,7 +2838,7 @@ array.get_u $packed-i16 ) - ;; CHECK: (func $array-set (type $47) (param $0 (ref $a2)) (param $1 i32) (param $2 f32) + ;; CHECK: (func $array-set (type $48) (param $0 (ref $a2)) (param $1 i32) (param $2 f32) ;; CHECK-NEXT: (array.set $a2 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2794,7 +2852,7 @@ array.set $a2 ) - ;; CHECK: (func $array-len (type $48) (param $0 arrayref) (result i32) + ;; CHECK: (func $array-len (type $49) (param $0 arrayref) (result i32) ;; CHECK-NEXT: (array.len ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: ) @@ -2804,7 +2862,7 @@ array.len ) - ;; CHECK: (func $array-copy (type $49) (param $0 (ref $a2)) (param $1 i32) (param $2 (ref $a2)) (param $3 i32) (param $4 i32) + ;; CHECK: (func $array-copy (type $50) (param $0 (ref $a2)) (param $1 i32) (param $2 (ref $a2)) (param $3 i32) (param $4 i32) ;; CHECK-NEXT: (array.copy $a2 $a2 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2822,7 +2880,7 @@ array.copy $a2 $a2 ) - ;; CHECK: (func $array-fill (type $50) (param $0 (ref $a2)) (param $1 i32) (param $2 f32) (param $3 i32) + ;; CHECK: (func $array-fill (type $51) (param $0 (ref $a2)) (param $1 i32) (param $2 f32) (param $3 i32) ;; CHECK-NEXT: (array.fill $a2 ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2851,7 +2909,7 @@ drop ) - ;; CHECK: (func $any-convert-extern (type $51) (param $0 externref) + ;; CHECK: (func $any-convert-extern (type $52) (param $0 externref) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (extern.internalize ;; CHECK-NEXT: (local.get $0) @@ -2877,7 +2935,7 @@ drop ) - ;; CHECK: (func $call (type $18) (param $0 i32) (param $1 i64) (result f32) + ;; CHECK: (func $call (type $19) (param $0 i32) (param $1 i64) (result f32) ;; CHECK-NEXT: (call $call ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2889,7 +2947,7 @@ call $call ) - ;; CHECK: (func $return_call (type $18) (param $0 i32) (param $1 i64) (result f32) + ;; CHECK: (func $return_call (type $19) (param $0 i32) (param $1 i64) (result f32) ;; CHECK-NEXT: (return_call $return_call ;; CHECK-NEXT: (local.get $0) ;; CHECK-NEXT: (local.get $1) @@ -2901,7 +2959,7 @@ return_call $return_call ) - ;; CHECK: (func $use-types (type $62) (param $0 (ref $s0)) (param $1 (ref $s1)) (param $2 (ref $s2)) (param $3 (ref $s3)) (param $4 (ref $s4)) (param $5 (ref $s5)) (param $6 (ref $s6)) (param $7 (ref $s7)) (param $8 (ref $s8)) (param $9 (ref $a0)) (param $10 (ref $a1)) (param $11 (ref $a2)) (param $12 (ref $a3)) (param $13 (ref $subvoid)) (param $14 (ref $submany)) + ;; CHECK: (func $use-types (type $63) (param $0 (ref $s0)) (param $1 (ref $s1)) (param $2 (ref $s2)) (param $3 (ref $s3)) (param $4 (ref $s4)) (param $5 (ref $s5)) (param $6 (ref $s6)) (param $7 (ref $s7)) (param $8 (ref $s8)) (param $9 (ref $a0)) (param $10 (ref $a1)) (param $11 (ref $a2)) (param $12 (ref $a3)) (param $13 (ref $subvoid)) (param $14 (ref $submany)) ;; CHECK-NEXT: (nop) ;; CHECK-NEXT: ) (func $use-types |