blob: 3cee5f3d441bf622ab3cca8684d20df20574cca2 [file] [log] [blame] [edit]
;; NOTE: Assertions have been generated by update_lit_checks.py and should not be edited.
;; RUN: wasm-opt %s --optimize-casts --enable-reference-types --enable-gc --enable-tail-call -S -o - | filecheck %s
(module
;; CHECK: (type $A (struct))
(type $A (struct))
;; CHECK: (func $yes-past-call (type $1) (param $x (ref struct))
;; CHECK-NEXT: (local $1 (ref $A))
;; CHECK-NEXT: (drop
;; CHECK-NEXT: (local.tee $1
;; CHECK-NEXT: (ref.cast (ref $A)
;; CHECK-NEXT: (local.get $x)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (call $none)
;; CHECK-NEXT: (drop
;; CHECK-NEXT: (local.get $1)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
(func $yes-past-call (param $x (ref struct))
(drop
(ref.cast (ref $A)
(local.get $x)
)
)
;; The call in the middle does not stop us from helping the last get, since
;; EH is not enabled. The last get will flip from $x to a new tee of the
;; cast.
(call $none)
(drop
(local.get $x)
)
)
;; CHECK: (func $yes-past-return_call (type $1) (param $x (ref struct))
;; CHECK-NEXT: (local $1 (ref $A))
;; CHECK-NEXT: (drop
;; CHECK-NEXT: (local.tee $1
;; CHECK-NEXT: (ref.cast (ref $A)
;; CHECK-NEXT: (local.get $x)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (return_call $none)
;; CHECK-NEXT: (drop
;; CHECK-NEXT: (local.get $1)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
(func $yes-past-return_call (param $x (ref struct))
(drop
(ref.cast (ref $A)
(local.get $x)
)
)
;; The call_return in the middle does not stop us from optimizing, since
;; after we branch out it doesn't matter what we have below.
(return_call $none)
(drop
(local.get $x)
)
)
;; CHECK: (func $none (type $2)
;; CHECK-NEXT: (nop)
;; CHECK-NEXT: )
(func $none
;; Helper for the above.
)
)