diff options
Diffstat (limited to 'test/lit/debug')
-rw-r--r-- | test/lit/debug/source-map-stop.wast | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/test/lit/debug/source-map-stop.wast b/test/lit/debug/source-map-stop.wast new file mode 100644 index 000000000..90bf739c1 --- /dev/null +++ b/test/lit/debug/source-map-stop.wast @@ -0,0 +1,122 @@ +;; NOTE: Assertions have been generated by update_lit_checks.py and should not be edited. + +;; RUN: wasm-opt %s -g -o %s.wasm -osm %s.wasm.map +;; RUN: wasm-opt %s.wasm -ism %s.wasm.map -S -o - | filecheck %s + +;; Verify that writing to a source map and reading it back does not "smear" +;; debug info across adjacent instructions. The debug info in the output should +;; be identical to the input. + +(module + ;; CHECK: (func $test (param $0 i32) (result i32) + ;; CHECK-NEXT: (drop + ;; CHECK-NEXT: (call $test + ;; CHECK-NEXT: ;;@ waka:100:1 + ;; CHECK-NEXT: (i32.const 1) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ;;@ waka:200:2 + ;; CHECK-NEXT: (i32.const 2) + ;; CHECK-NEXT: ) + (func $test (param i32) (result i32) + ;; The drop&call have no debug info, and should remain so. Specifically the + ;; instruction right before them in the binary (the const 1) should not + ;; smear its debug info on it. And the drop is between an instruction that + ;; has debug info (the const 1) and another (the i32.const 2): we should not + ;; receive the debug info of either. (This is a regression test for a bug + ;; that only happens in that state: removing the debug info either before or + ;; after would avoid that bug.) + + (drop + (call $test + ;;@ waka:100:1 + (i32.const 1) + ) + ) + ;;@ waka:200:2 + (i32.const 2) + ) + + ;; CHECK: (func $same-later (param $0 i32) (result i32) + ;; CHECK-NEXT: (drop + ;; CHECK-NEXT: (call $test + ;; CHECK-NEXT: ;;@ waka:100:1 + ;; CHECK-NEXT: (i32.const 1) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ;;@ waka:100:1 + ;; CHECK-NEXT: (i32.const 2) + ;; CHECK-NEXT: ) + (func $same-later (param i32) (result i32) + ;; As the first, but now the later debug info is also 100:1. No debug info + ;; should change here. + + (drop + (call $test + ;;@ waka:100:1 + (i32.const 1) + ) + ) + ;;@ waka:100:1 + (i32.const 2) + ) + + ;; CHECK: (func $more-before (param $0 i32) (result i32) + ;; CHECK-NEXT: ;;@ waka:50:5 + ;; CHECK-NEXT: (nop) + ;; CHECK-NEXT: ;;@ waka:50:5 + ;; CHECK-NEXT: (drop + ;; CHECK-NEXT: (call $test + ;; CHECK-NEXT: ;;@ waka:100:1 + ;; CHECK-NEXT: (i32.const 1) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ;;@ waka:200:2 + ;; CHECK-NEXT: (i32.const 2) + ;; CHECK-NEXT: ) + (func $more-before (param i32) (result i32) + ;; As the first, but now there is more debug info before the 100:1 (the + ;; very first debug info in a function has special handling, so we test it + ;; more carefully). + ;; + ;; The s-parser actually smears 50:5 on the drop and call after it, so the + ;; output here looks incorrect. This may be a bug there, TODO + + ;;@ waka:50:5 + (nop) + (drop + (call $test + ;;@ waka:100:1 + (i32.const 1) + ) + ) + ;;@ waka:200:2 + (i32.const 2) + ) + + ;; CHECK: (func $nothing-before (param $0 i32) (result i32) + ;; CHECK-NEXT: (nop) + ;; CHECK-NEXT: (drop + ;; CHECK-NEXT: (call $test + ;; CHECK-NEXT: ;;@ waka:100:1 + ;; CHECK-NEXT: (i32.const 1) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ;;@ waka:200:2 + ;; CHECK-NEXT: (i32.const 2) + ;; CHECK-NEXT: ) + (func $nothing-before (param i32) (result i32) + ;; As before, but no debug info on the nop before us (so the first + ;; instruction in the function no longer has a debug annotation). Nothing + ;; should change in the debug info. + (nop) + (drop + (call $test + ;;@ waka:100:1 + (i32.const 1) + ) + ) + ;;@ waka:200:2 + (i32.const 2) + ) +) |