summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2023-08-17 18:56:34 -0700
committerGitHub <noreply@github.com>2023-08-17 18:56:34 -0700
commitb41ec7cb488481e5b1a57fc7203e9c0bc7331bbd (patch)
treec4ad18a571e1a79a164d5c3a670fc7f0b7b70fe5 /test
parentf044172ed665e94e61f579a8fc19770bb56f7b65 (diff)
downloadbinaryen-b41ec7cb488481e5b1a57fc7203e9c0bc7331bbd.tar.gz
binaryen-b41ec7cb488481e5b1a57fc7203e9c0bc7331bbd.tar.bz2
binaryen-b41ec7cb488481e5b1a57fc7203e9c0bc7331bbd.zip
Fix SSA on null refinement (#5886)
Similar to #5885 this was uncovered by #5881 #5882. Here we need to refinalize when we replace a local.get with a null, since the null's type is more refined.
Diffstat (limited to 'test')
-rw-r--r--test/lit/passes/ssa.wast28
1 files changed, 28 insertions, 0 deletions
diff --git a/test/lit/passes/ssa.wast b/test/lit/passes/ssa.wast
index ed5b94f7b..06fe450aa 100644
--- a/test/lit/passes/ssa.wast
+++ b/test/lit/passes/ssa.wast
@@ -2,6 +2,9 @@
;; RUN: wasm-opt %s -all --ssa -S -o - | filecheck %s
(module
+ ;; CHECK: (type $A (struct ))
+ (type $A (struct ))
+
;; CHECK: (func $foo (type $none_=>_none)
;; CHECK-NEXT: (nop)
;; CHECK-NEXT: )
@@ -31,4 +34,29 @@
(local.set $x (ref.func $bar))
(drop (local.get $x))
)
+
+ ;; CHECK: (func $refine-to-null (type $none_=>_ref|$A|) (result (ref $A))
+ ;; CHECK-NEXT: (local $0 (ref null $A))
+ ;; CHECK-NEXT: (block $label (result (ref none))
+ ;; CHECK-NEXT: (drop
+ ;; CHECK-NEXT: (br_on_cast $label nullref (ref none)
+ ;; CHECK-NEXT: (ref.null none)
+ ;; CHECK-NEXT: )
+ ;; CHECK-NEXT: )
+ ;; CHECK-NEXT: (unreachable)
+ ;; CHECK-NEXT: )
+ ;; CHECK-NEXT: )
+ (func $refine-to-null (result (ref $A))
+ (local $0 (ref null $A))
+ (block $label (result (ref $A))
+ (drop
+ (br_on_cast $label (ref null $A) (ref $A)
+ ;; This will turn into a null, which has a more refined type that affects
+ ;; the br_on_cast parent.
+ (local.get $0)
+ )
+ )
+ (unreachable)
+ )
+ )
)