1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
|
;; NOTE: Assertions have been generated by update_lit_checks.py --all-items and should not be edited.
;; RUN: foreach %s %t wasm-opt --closed-world -tnh --type-merging --remove-unused-types -all -S -o - | filecheck %s
;; ref.cast does not inhibit merging if traps never happen.
(module
;; CHECK: (rec
;; CHECK-NEXT: (type $A (sub (struct)))
(type $A (sub (struct)))
(type $B (sub $A (struct)))
;; CHECK: (type $1 (func (param (ref $A)) (result (ref $A))))
;; CHECK: (func $test (type $1) (param $a (ref $A)) (result (ref $A))
;; CHECK-NEXT: (ref.cast (ref $A)
;; CHECK-NEXT: (local.get $a)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
(func $test (param $a (ref $A)) (result (ref $B))
(ref.cast (ref $B)
(local.get $a)
)
)
)
;; Check that a ref.test still inhibits merging with -tnh.
(module
;; CHECK: (rec
;; CHECK-NEXT: (type $A (sub (struct)))
(type $A (sub (struct)))
;; CHECK: (type $B (sub $A (struct)))
(type $B (sub $A (struct)))
;; CHECK: (type $2 (func (param (ref $A)) (result i32)))
;; CHECK: (func $test (type $2) (param $a (ref $A)) (result i32)
;; CHECK-NEXT: (ref.test (ref $B)
;; CHECK-NEXT: (local.get $a)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
(func $test (param $a (ref $A)) (result i32)
(ref.test (ref $B)
(local.get $a)
)
)
)
;; Check that a br_on_cast still inhibits merging with -tnh.
(module
;; CHECK: (rec
;; CHECK-NEXT: (type $A (sub (struct)))
(type $A (sub (struct)))
;; CHECK: (type $B (sub $A (struct)))
(type $B (sub $A (struct)))
;; CHECK: (type $2 (func (param (ref $A)) (result (ref $B))))
;; CHECK: (func $test (type $2) (param $a (ref $A)) (result (ref $B))
;; CHECK-NEXT: (block $label (result (ref $B))
;; CHECK-NEXT: (drop
;; CHECK-NEXT: (br_on_cast $label (ref $A) (ref $B)
;; CHECK-NEXT: (local.get $a)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (drop
;; CHECK-NEXT: (block $l (result (ref $A))
;; CHECK-NEXT: (br_on_non_null $l
;; CHECK-NEXT: (local.get $a)
;; CHECK-NEXT: )
;; CHECK-NEXT: (unreachable)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (unreachable)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
(func $test (param $a (ref $A)) (result (ref $B))
(drop
(br_on_cast 0 anyref (ref $B)
(local.get $a)
)
)
;; Also check that a different br_on* doesn't confuse us.
(drop
(block $l (result (ref $A))
(br_on_non_null $l
(local.get $a)
)
(unreachable)
)
)
(unreachable)
)
)
;; call_indirect should not inhibit merging if traps never happen.
(module
;; CHECK: (type $A (sub (func)))
(type $A (sub (func)))
(type $B (sub $A (func)))
(table 1 1 (ref null $A))
;; CHECK: (table $0 1 1 (ref null $A))
;; CHECK: (func $test (type $A)
;; CHECK-NEXT: (call_indirect $0 (type $A)
;; CHECK-NEXT: (i32.const 0)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
(func $test (type $A)
(call_indirect (type $B)
(i32.const 0)
)
)
)
|