summaryrefslogtreecommitdiff
path: root/test/spec/table_set.wast
diff options
context:
space:
mode:
authorSam Clegg <sbc@chromium.org>2024-05-10 16:33:38 -0700
committerGitHub <noreply@github.com>2024-05-10 23:33:38 +0000
commitabc430b617385f3e989f85e7bd1c2a9d838fd217 (patch)
tree5a7869083ae64cc59a04cb5512b3f175fade02d5 /test/spec/table_set.wast
parent9975b56614d4a5560b35f009be20d51e360b69dc (diff)
downloadbinaryen-abc430b617385f3e989f85e7bd1c2a9d838fd217.tar.gz
binaryen-abc430b617385f3e989f85e7bd1c2a9d838fd217.tar.bz2
binaryen-abc430b617385f3e989f85e7bd1c2a9d838fd217.zip
[memory64] Add table64 to existing memory64 support (#6577)
Tests is still very limited. Hopefully we can use the upstream spec tests soon and avoid having to write our own tests for `.set/.set/.fill/etc`. See https://github.com/WebAssembly/memory64/issues/51
Diffstat (limited to 'test/spec/table_set.wast')
-rw-r--r--test/spec/table_set.wast12
1 files changed, 11 insertions, 1 deletions
diff --git a/test/spec/table_set.wast b/test/spec/table_set.wast
index 6034f146f..7ec3fc6c2 100644
--- a/test/spec/table_set.wast
+++ b/test/spec/table_set.wast
@@ -1,6 +1,7 @@
(module
(table $t2 1 externref)
(table $t3 2 funcref)
+ (table $t64 i64 2 funcref)
(elem (table $t3) (i32.const 1) func $dummy)
(func $dummy)
@@ -10,9 +11,12 @@
(func $f3 (export "get-funcref") (param $i i32) (result funcref)
(table.get $t3 (local.get $i))
)
+ (func $f4 (export "get-funcref-t64") (param $i i64) (result funcref)
+ (table.get $t64 (local.get $i))
+ )
(func (export "set-externref") (param $i i32) (param $r externref)
- (table.set $t2 (local.get $i) (local.get $r))
+ (table.set (local.get $i) (local.get $r))
)
(func (export "set-funcref") (param $i i32) (param $r funcref)
(table.set $t3 (local.get $i) (local.get $r))
@@ -20,6 +24,9 @@
(func (export "set-funcref-from") (param $i i32) (param $j i32)
(table.set $t3 (local.get $i) (table.get $t3 (local.get $j)))
)
+ (func (export "set-funcref-t64") (param $i i64) (param $r funcref)
+ (table.set $t64 (local.get $i) (local.get $r))
+ )
(func (export "is_null-funcref") (param $i i32) (result i32)
(ref.is_null (call $f3 (local.get $i)))
@@ -32,6 +39,9 @@
(assert_return (invoke "set-externref" (i32.const 0) (ref.null extern)))
(assert_return (invoke "get-externref" (i32.const 0)) (ref.null extern))
+(assert_return (invoke "set-funcref-t64" (i64.const 0) (ref.null func)))
+(assert_return (invoke "get-funcref-t64" (i64.const 0)) (ref.null func))
+
(assert_return (invoke "get-funcref" (i32.const 0)) (ref.null func))
(assert_return (invoke "set-funcref-from" (i32.const 0) (i32.const 1)))
(assert_return (invoke "is_null-funcref" (i32.const 0)) (i32.const 0))