summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/lit/passes/global-refining.wast83
1 files changed, 82 insertions, 1 deletions
diff --git a/test/lit/passes/global-refining.wast b/test/lit/passes/global-refining.wast
index 06af50bf1..980194c91 100644
--- a/test/lit/passes/global-refining.wast
+++ b/test/lit/passes/global-refining.wast
@@ -1,20 +1,28 @@
;; NOTE: Assertions have been generated by update_lit_checks.py --all-items and should not be edited.
-;; RUN: foreach %s %t wasm-opt --nominal --global-refining -all -S -o - | filecheck %s
+
+;; RUN: foreach %s %t wasm-opt --nominal --global-refining -all -S -o - | filecheck %s
+;; RUN: foreach %s %t wasm-opt --nominal --global-refining --closed-world -all -S -o - | filecheck %s --check-prefix=CLOSD
(module
;; Globals with no assignments aside from their initial values. The first is a
;; null, so we can optimize to a nullfuncref. The second is a ref.func which
;; lets us refine to the specific function type.
;; CHECK: (type $foo_t (func))
+ ;; CLOSD: (type $foo_t (func))
(type $foo_t (func))
;; CHECK: (global $func-null-init (mut nullfuncref) (ref.null nofunc))
+ ;; CLOSD: (global $func-null-init (mut nullfuncref) (ref.null nofunc))
(global $func-null-init (mut funcref) (ref.null $foo_t))
;; CHECK: (global $func-func-init (mut (ref $foo_t)) (ref.func $foo))
+ ;; CLOSD: (global $func-func-init (mut (ref $foo_t)) (ref.func $foo))
(global $func-func-init (mut funcref) (ref.func $foo))
;; CHECK: (func $foo (type $foo_t)
;; CHECK-NEXT: (nop)
;; CHECK-NEXT: )
+ ;; CLOSD: (func $foo (type $foo_t)
+ ;; CLOSD-NEXT: (nop)
+ ;; CLOSD-NEXT: )
(func $foo (type $foo_t))
)
@@ -23,11 +31,14 @@
;; init will update the null to allow it to refine.
;; CHECK: (type $foo_t (func))
+ ;; CLOSD: (type $foo_t (func))
(type $foo_t (func))
;; CHECK: (global $func-null-init (mut nullfuncref) (ref.null nofunc))
+ ;; CLOSD: (global $func-null-init (mut nullfuncref) (ref.null nofunc))
(global $func-null-init (mut funcref) (ref.null $foo_t))
;; CHECK: (global $func-func-init (mut (ref null $foo_t)) (ref.func $foo))
+ ;; CLOSD: (global $func-func-init (mut (ref null $foo_t)) (ref.func $foo))
(global $func-func-init (mut funcref) (ref.func $foo))
;; CHECK: (func $foo (type $foo_t)
@@ -38,6 +49,14 @@
;; CHECK-NEXT: (ref.null nofunc)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
+ ;; CLOSD: (func $foo (type $foo_t)
+ ;; CLOSD-NEXT: (global.set $func-null-init
+ ;; CLOSD-NEXT: (ref.null nofunc)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: (global.set $func-func-init
+ ;; CLOSD-NEXT: (ref.null nofunc)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: )
(func $foo (type $foo_t)
(global.set $func-null-init (ref.null func))
(global.set $func-func-init (ref.null $foo_t))
@@ -51,8 +70,12 @@
;; CHECK: (type $none_=>_none (func))
;; CHECK: (global $func-null-init (mut (ref null $none_=>_none)) (ref.null nofunc))
+ ;; CLOSD: (type $none_=>_none (func))
+
+ ;; CLOSD: (global $func-null-init (mut (ref null $none_=>_none)) (ref.null nofunc))
(global $func-null-init (mut funcref) (ref.null func))
;; CHECK: (global $func-func-init (mut (ref $none_=>_none)) (ref.func $foo))
+ ;; CLOSD: (global $func-func-init (mut (ref $none_=>_none)) (ref.func $foo))
(global $func-func-init (mut funcref) (ref.func $foo))
;; CHECK: (elem declare func $foo)
@@ -65,6 +88,16 @@
;; CHECK-NEXT: (ref.func $foo)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
+ ;; CLOSD: (elem declare func $foo)
+
+ ;; CLOSD: (func $foo (type $none_=>_none)
+ ;; CLOSD-NEXT: (global.set $func-null-init
+ ;; CLOSD-NEXT: (ref.func $foo)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: (global.set $func-func-init
+ ;; CLOSD-NEXT: (ref.func $foo)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: )
(func $foo
(global.set $func-null-init (ref.func $foo))
(global.set $func-func-init (ref.func $foo))
@@ -78,10 +111,14 @@
;; CHECK: (type $none_=>_none (func))
;; CHECK: (type $struct (struct ))
+ ;; CLOSD: (type $none_=>_none (func))
+
+ ;; CLOSD: (type $struct (struct ))
(type $struct (struct))
(type $array (array i8))
;; CHECK: (global $global (mut eqref) (ref.null none))
+ ;; CLOSD: (global $global (mut eqref) (ref.null none))
(global $global (mut anyref) (ref.null any))
;; CHECK: (func $foo (type $none_=>_none)
@@ -103,6 +140,25 @@
;; CHECK-NEXT: (ref.null none)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
+ ;; CLOSD: (func $foo (type $none_=>_none)
+ ;; CLOSD-NEXT: (global.set $global
+ ;; CLOSD-NEXT: (i31.new
+ ;; CLOSD-NEXT: (i32.const 0)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: (global.set $global
+ ;; CLOSD-NEXT: (struct.new_default $struct)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: (global.set $global
+ ;; CLOSD-NEXT: (ref.null none)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: (global.set $global
+ ;; CLOSD-NEXT: (ref.null none)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: (global.set $global
+ ;; CLOSD-NEXT: (ref.null none)
+ ;; CLOSD-NEXT: )
+ ;; CLOSD-NEXT: )
(func $foo
(global.set $global (i31.new (i32.const 0)))
(global.set $global (struct.new_default $struct))
@@ -112,3 +168,28 @@
(global.set $global (ref.null $array))
)
)
+
+;; We can refine here, but as it is an export we only do so in open world.
+(module
+ ;; CHECK: (type $none_=>_none (func))
+
+ ;; CHECK: (global $func-init (mut (ref $none_=>_none)) (ref.func $foo))
+ ;; CLOSD: (type $none_=>_none (func))
+
+ ;; CLOSD: (global $func-init (mut funcref) (ref.func $foo))
+ (global $func-init (mut funcref) (ref.func $foo))
+
+ ;; CHECK: (export "global" (global $func-init))
+ ;; CLOSD: (export "global" (global $func-init))
+ (export "global" (global $func-init))
+
+ ;; CHECK: (func $foo (type $none_=>_none)
+ ;; CHECK-NEXT: (nop)
+ ;; CHECK-NEXT: )
+ ;; CLOSD: (func $foo (type $none_=>_none)
+ ;; CLOSD-NEXT: (nop)
+ ;; CLOSD-NEXT: )
+ (func $foo
+ (nop)
+ )
+)