diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/lit/ctor-eval/extern.wast | 113 | ||||
-rw-r--r-- | test/lit/passes/precompute-ref-func.wast | 36 |
2 files changed, 131 insertions, 18 deletions
diff --git a/test/lit/ctor-eval/extern.wast b/test/lit/ctor-eval/extern.wast index 9591f9034..d8e08eaa2 100644 --- a/test/lit/ctor-eval/extern.wast +++ b/test/lit/ctor-eval/extern.wast @@ -1,18 +1,19 @@ ;; NOTE: Assertions have been generated by update_lit_checks.py --all-items and should not be edited. -;; RUN: wasm-ctor-eval %s --ctors=test1,test2,test3 --kept-exports=test1,test2,test3 --quiet -all -S -o - | filecheck %s +;; RUN: wasm-ctor-eval %s --ctors=test1,test1-shared,test2,test2-shared,test3,test3-shared \ +;; RUN: --kept-exports=test1,test1-shared,test2,test2-shared,test3,test3-shared --quiet -all -S -o - | filecheck %s (module ;; CHECK: (type $array (array (mut i8))) (type $array (array (mut i8))) + ;; CHECK: (type $shared-array (shared (array (mut i8)))) + (type $shared-array (shared (array (mut i8)))) ;; CHECK: (type $struct (struct (field externref))) (type $struct (struct (field externref))) + ;; CHECK: (type $shared-struct (shared (struct (field (ref null (shared extern)))))) + (type $shared-struct (shared (struct (field (ref null (shared extern)))))) - (export "test1" (func $test1)) - (export "test2" (func $test2)) - (export "test3" (func $test3)) - - (func $test1 (result externref) + (func $test1 (export "test1") (result externref) ;; This will remain almost the same, even though we eval it, since the ;; serialization of an externalized i31 is what is written here. But the add ;; will be evalled out. @@ -26,7 +27,19 @@ ) ) - (func $test2 (result externref) + (func $test1-shared (export "test1-shared") (result (ref null (shared extern))) + ;; Same as above, but now the i31 is shared. + (extern.convert_any + (ref.i31_shared + (i32.add + (i32.const 41) + (i32.const 1) + ) + ) + ) + ) + + (func $test2 (export "test2") (result externref) ;; This will be evalled into an externalization of a global.get. (extern.convert_any (array.new_fixed $array 3 @@ -37,7 +50,18 @@ ) ) - (func $test3 (result anyref) + (func $test2-shared (export "test2-shared") (result (ref null (shared extern))) + ;; Same as above, but now the array is shared. + (extern.convert_any + (array.new_fixed $shared-array 3 + (i32.const 1) + (i32.const 2) + (i32.const 3) + ) + ) + ) + + (func $test3 (export "test3") (result anyref) ;; This will add a global that contains an externalization operation. (struct.new $struct (extern.convert_any @@ -47,11 +71,26 @@ ) ) ) + + (func $test3-shared (export "test3-shared") (result (ref null (shared any))) + ;; Same as above, but now the struct and i31 are shared. + (struct.new $shared-struct + (extern.convert_any + (ref.i31_shared + (i32.const 1) + ) + ) + ) + ) ) -;; CHECK: (type $2 (func (result externref))) +;; CHECK: (type $4 (func (result externref))) + +;; CHECK: (type $5 (func (result (ref null (shared extern))))) + +;; CHECK: (type $6 (func (result anyref))) -;; CHECK: (type $3 (func (result anyref))) +;; CHECK: (type $7 (func (result (ref null (shared any))))) ;; CHECK: (global $ctor-eval$global (ref $array) (array.new_fixed $array 3 ;; CHECK-NEXT: (i32.const 1) @@ -59,7 +98,13 @@ ;; CHECK-NEXT: (i32.const 3) ;; CHECK-NEXT: )) -;; CHECK: (global $ctor-eval$global_1 (ref $struct) (struct.new $struct +;; CHECK: (global $ctor-eval$global_1 (ref $shared-array) (array.new_fixed $shared-array 3 +;; CHECK-NEXT: (i32.const 1) +;; CHECK-NEXT: (i32.const 2) +;; CHECK-NEXT: (i32.const 3) +;; CHECK-NEXT: )) + +;; CHECK: (global $ctor-eval$global_2 (ref $struct) (struct.new $struct ;; CHECK-NEXT: (extern.convert_any ;; CHECK-NEXT: (ref.i31 ;; CHECK-NEXT: (i32.const 1) @@ -67,13 +112,27 @@ ;; CHECK-NEXT: ) ;; CHECK-NEXT: )) -;; CHECK: (export "test1" (func $test1_3)) +;; CHECK: (global $ctor-eval$global_3 (ref $shared-struct) (struct.new $shared-struct +;; CHECK-NEXT: (extern.convert_any +;; CHECK-NEXT: (ref.i31_shared +;; CHECK-NEXT: (i32.const 1) +;; CHECK-NEXT: ) +;; CHECK-NEXT: ) +;; CHECK-NEXT: )) + +;; CHECK: (export "test1" (func $test1_6)) + +;; CHECK: (export "test1-shared" (func $test1-shared_7)) + +;; CHECK: (export "test2" (func $test2_8)) -;; CHECK: (export "test2" (func $test2_4)) +;; CHECK: (export "test2-shared" (func $test2-shared_9)) -;; CHECK: (export "test3" (func $test3_5)) +;; CHECK: (export "test3" (func $test3_10)) -;; CHECK: (func $test1_3 (type $2) (result externref) +;; CHECK: (export "test3-shared" (func $test3-shared_11)) + +;; CHECK: (func $test1_6 (type $4) (result externref) ;; CHECK-NEXT: (extern.convert_any ;; CHECK-NEXT: (ref.i31 ;; CHECK-NEXT: (i32.const 42) @@ -81,12 +140,30 @@ ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) -;; CHECK: (func $test2_4 (type $2) (result externref) +;; CHECK: (func $test1-shared_7 (type $5) (result (ref null (shared extern))) +;; CHECK-NEXT: (extern.convert_any +;; CHECK-NEXT: (ref.i31_shared +;; CHECK-NEXT: (i32.const 42) +;; CHECK-NEXT: ) +;; CHECK-NEXT: ) +;; CHECK-NEXT: ) + +;; CHECK: (func $test2_8 (type $4) (result externref) ;; CHECK-NEXT: (extern.convert_any ;; CHECK-NEXT: (global.get $ctor-eval$global) ;; CHECK-NEXT: ) ;; CHECK-NEXT: ) -;; CHECK: (func $test3_5 (type $3) (result anyref) -;; CHECK-NEXT: (global.get $ctor-eval$global_1) +;; CHECK: (func $test2-shared_9 (type $5) (result (ref null (shared extern))) +;; CHECK-NEXT: (extern.convert_any +;; CHECK-NEXT: (global.get $ctor-eval$global_1) +;; CHECK-NEXT: ) +;; CHECK-NEXT: ) + +;; CHECK: (func $test3_10 (type $6) (result anyref) +;; CHECK-NEXT: (global.get $ctor-eval$global_2) +;; CHECK-NEXT: ) + +;; CHECK: (func $test3-shared_11 (type $7) (result (ref null (shared any))) +;; CHECK-NEXT: (global.get $ctor-eval$global_3) ;; CHECK-NEXT: ) diff --git a/test/lit/passes/precompute-ref-func.wast b/test/lit/passes/precompute-ref-func.wast new file mode 100644 index 000000000..df4415c7b --- /dev/null +++ b/test/lit/passes/precompute-ref-func.wast @@ -0,0 +1,36 @@ +;; NOTE: Assertions have been generated by update_lit_checks.py --all-items and should not be edited. +;; RUN: wasm-opt %s -all --precompute -S -o - | filecheck %s + +(module + ;; CHECK: (type $0 (func (result funcref))) + + ;; CHECK: (type $shared-func (shared (func (result (ref null (shared func)))))) + (type $shared-func (shared (func (result (ref null (shared func)))))) + ;; CHECK: (elem declare func $test $test-shared) + + ;; CHECK: (func $test (type $0) (result funcref) + ;; CHECK-NEXT: (return + ;; CHECK-NEXT: (ref.func $test) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + (func $test (result funcref) + (block + (return + (ref.func $test) + ) + ) + ) + + ;; CHECK: (func $test-shared (type $shared-func) (result (ref null (shared func))) + ;; CHECK-NEXT: (return + ;; CHECK-NEXT: (ref.func $test-shared) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + (func $test-shared (type $shared-func) + (block + (return + (ref.func $test-shared) + ) + ) + ) +) |