diff options
author | Alon Zakai <azakai@google.com> | 2023-10-25 13:29:17 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-10-25 20:29:17 +0000 |
commit | 7a6d9621f5a654a541e4ad9a6313b47495ea9a62 (patch) | |
tree | 2d4cf07f8d5140889dd057251548d543dc26afd3 /test | |
parent | ea6bcd01d95466c9178380f9031a2be9505bdf23 (diff) | |
download | binaryen-7a6d9621f5a654a541e4ad9a6313b47495ea9a62.tar.gz binaryen-7a6d9621f5a654a541e4ad9a6313b47495ea9a62.tar.bz2 binaryen-7a6d9621f5a654a541e4ad9a6313b47495ea9a62.zip |
Precompute: Check defaultability, not nullability (#6052)
Followup to #6048, we did not handle nondefaultable tuples because of this.
Diffstat (limited to 'test')
-rw-r--r-- | test/lit/passes/precompute-gc.wast | 41 |
1 files changed, 33 insertions, 8 deletions
diff --git a/test/lit/passes/precompute-gc.wast b/test/lit/passes/precompute-gc.wast index 3a16eddbc..901ad5c24 100644 --- a/test/lit/passes/precompute-gc.wast +++ b/test/lit/passes/precompute-gc.wast @@ -229,7 +229,7 @@ (struct.get $struct 0 (local.get $x)) ) ) - ;; CHECK: (func $ref-comparisons (type $10) (param $x (ref null $struct)) (param $y (ref null $struct)) + ;; CHECK: (func $ref-comparisons (type $11) (param $x (ref null $struct)) (param $y (ref null $struct)) ;; CHECK-NEXT: (local $z (ref null $struct)) ;; CHECK-NEXT: (local $w (ref null $struct)) ;; CHECK-NEXT: (call $log @@ -407,7 +407,7 @@ (local.get $tempresult) ) - ;; CHECK: (func $propagate-different-params (type $11) (param $input1 (ref $empty)) (param $input2 (ref $empty)) (result i32) + ;; CHECK: (func $propagate-different-params (type $12) (param $input1 (ref $empty)) (param $input2 (ref $empty)) (result i32) ;; CHECK-NEXT: (local $tempresult i32) ;; CHECK-NEXT: (local.set $tempresult ;; CHECK-NEXT: (ref.eq @@ -723,7 +723,7 @@ ) ) - ;; CHECK: (func $helper (type $12) (param $0 i32) (result i32) + ;; CHECK: (func $helper (type $13) (param $0 i32) (result i32) ;; CHECK-NEXT: (unreachable) ;; CHECK-NEXT: ) (func $helper (param i32) (result i32) @@ -801,14 +801,14 @@ ) ) - ;; CHECK: (func $receive-f64 (type $13) (param $0 f64) + ;; CHECK: (func $receive-f64 (type $14) (param $0 f64) ;; CHECK-NEXT: (unreachable) ;; CHECK-NEXT: ) (func $receive-f64 (param f64) (unreachable) ) - ;; CHECK: (func $odd-cast-and-get-non-null (type $14) (param $temp (ref $func-return-i32)) + ;; CHECK: (func $odd-cast-and-get-non-null (type $15) (param $temp (ref $func-return-i32)) ;; CHECK-NEXT: (local.set $temp ;; CHECK-NEXT: (ref.cast (ref nofunc) ;; CHECK-NEXT: (ref.func $receive-f64) @@ -857,7 +857,7 @@ ) ) - ;; CHECK: (func $br_on_cast-on-creation (type $15) (result (ref $empty)) + ;; CHECK: (func $br_on_cast-on-creation (type $16) (result (ref $empty)) ;; CHECK-NEXT: (block $label (result (ref $empty)) ;; CHECK-NEXT: (drop ;; CHECK-NEXT: (br_on_cast $label (ref $empty) (ref $empty) @@ -952,7 +952,7 @@ ) ) - ;; CHECK: (func $remove-set (type $16) (result (ref func)) + ;; CHECK: (func $remove-set (type $17) (result (ref func)) ;; CHECK-NEXT: (local $nn funcref) ;; CHECK-NEXT: (local $i i32) ;; CHECK-NEXT: (loop $loop @@ -995,7 +995,7 @@ ) ) - ;; CHECK: (func $strings (type $17) (param $param (ref string)) + ;; CHECK: (func $strings (type $18) (param $param (ref string)) ;; CHECK-NEXT: (local $s (ref string)) ;; CHECK-NEXT: (local.set $s ;; CHECK-NEXT: (string.const "hello, world") @@ -1141,4 +1141,29 @@ ) ) ) + + ;; CHECK: (func $get-nonnullable-in-unreachable-tuple (type $19) (result anyref i32) + ;; CHECK-NEXT: (local $x ((ref any) i32)) + ;; CHECK-NEXT: (local.tee $x + ;; CHECK-NEXT: (unreachable) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: (if + ;; CHECK-NEXT: (i32.const 1) + ;; CHECK-NEXT: (unreachable) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: (local.get $x) + ;; CHECK-NEXT: ) + (func $get-nonnullable-in-unreachable-tuple (result anyref i32) + ;; As $get-nonnullable-in-unreachable but the local is a tuple (so we need to + ;; check isDefaultable, and not just isNullable). + (local $x ((ref any) i32)) + (local.set $x + (unreachable) + ) + (if + (i32.const 1) + (unreachable) + ) + (local.get $x) + ) ) |