| ;; NOTE: Assertions have been generated by update_lit_checks.py --all-items and should not be edited. |
| ;; NOTE: This test was ported using port_passes_tests_to_lit.py and could be cleaned up. |
| |
| ;; RUN: foreach %s %t wasm-opt --code-pushing -tnh -S -o - | filecheck %s |
| |
| (module |
| ;; CHECK: (type $0 (func (param i32 i32))) |
| |
| ;; CHECK: (type $1 (func)) |
| |
| ;; CHECK: (func $div (param $x i32) (param $y i32) |
| ;; CHECK-NEXT: (local $temp i32) |
| ;; CHECK-NEXT: (block $block |
| ;; CHECK-NEXT: (if |
| ;; CHECK-NEXT: (local.get $y) |
| ;; CHECK-NEXT: (return) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: (local.set $temp |
| ;; CHECK-NEXT: (i32.div_u |
| ;; CHECK-NEXT: (i32.const 1) |
| ;; CHECK-NEXT: (local.get $x) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: (drop |
| ;; CHECK-NEXT: (local.get $temp) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: ) |
| (func $div (param $x i32) (param $y i32) |
| (local $temp i32) |
| (block $block |
| ;; This division might trap (if x is 0). But with tnh we can assume that |
| ;; won't happen, and push it past the condition. |
| (local.set $temp |
| (i32.div_u |
| (i32.const 1) |
| (local.get $x) |
| ) |
| ) |
| (if |
| (local.get $y) |
| (return) |
| ) |
| (drop |
| (local.get $temp) |
| ) |
| ) |
| ) |
| |
| ;; CHECK: (func $unreachable-value |
| ;; CHECK-NEXT: (local $x i32) |
| ;; CHECK-NEXT: (local.tee $x |
| ;; CHECK-NEXT: (unreachable) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: (if |
| ;; CHECK-NEXT: (i32.const 0) |
| ;; CHECK-NEXT: (drop |
| ;; CHECK-NEXT: (local.get $x) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: ) |
| ;; CHECK-NEXT: ) |
| (func $unreachable-value |
| (local $x i32) |
| ;; We should not push this into the if. (If we did, we'd need to refinalize |
| ;; the block, or we'd error; instead, leave this to DCE.) |
| (local.set $x |
| (unreachable) |
| ) |
| (if |
| (i32.const 0) |
| (drop |
| (local.get $x) |
| ) |
| ) |
| ) |
| ) |