summaryrefslogtreecommitdiff
path: root/test/lit/binary/dwarf-multivalue.test
blob: 250a861bf3cc262adb9a069ead8b845b1fc2137c (plain)
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
;; Test that we handle multivalue + DWARF correctly. When we need to preserve
;; DWARF info, we don't do any local reordering and all newly added locals
;; during parsing/writing are added at the end of the local list.

;; Generated from this c file with the following command:
;; $ emcc -g -Xclang -target-abi -Xclang experimental-mv dwarf-multivalue.c -o dwarf-multivalue.wasm
;;
;; struct MyStruct {
;;   int a;
;;   float b;
;; };
;;
;; struct MyStruct foo() {
;;   struct MyStruct ret = {.a = 3, .b = 3.5};
;;   return ret;
;; }
;;
;; void test() {
;;   struct MyStruct s = foo();
;; }
;;
;; int main() {
;;   test();
;;   return 0;
;; }

;; The original wasm file's $test function's locals are as follows:
;; (func $test
;;  (local $0 i32)
;;  (local $1 i32)
;;  (local $2 i32)
;;  (local $3 i32)
;;  (local $4 f32)
;;  (local $5 i32)
;;  (local $6 i32)
;;  (local $7 i32)
;;  (local $8 f32)
;;  (local $9 i32)
;;  (local $10 f32)

;; If we parse this wasm file into Binaryen IR, two locals are added in the
;; process. Here $scratch is added for tuple parsing and $scratch_12 is added
;; for stacky IR resolving during binary reading process.
;; RUN: wasm-dis %s.wasm -o - | filecheck %s --check-prefix=ORIG
;; ORIG:      (func $test
;; ORIG-NEXT:  (local $0 i32)
;; ORIG-NEXT:  (local $1 i32)
;; ORIG-NEXT:  (local $2 i32)
;; ORIG-NEXT:  (local $3 i32)
;; ORIG-NEXT:  (local $4 f32)
;; ORIG-NEXT:  (local $5 i32)
;; ORIG-NEXT:  (local $6 i32)
;; ORIG-NEXT:  (local $7 i32)
;; ORIG-NEXT:  (local $8 f32)
;; ORIG-NEXT:  (local $9 i32)
;; ORIG-NEXT:  (local $10 f32)
;; ORIG-NEXT:  (local $scratch (tuple i32 f32))
;; ORIG-NEXT:  (local $scratch_12 i32)

;; If we write this IR into binary, even if this cannot be displayed in the wast
;; format, the local order of $test will look like this, because we don't
;; reorder locals:
;; (func $test
;;  (local $0 i32)
;;  (local $1 i32)
;;  (local $2 i32)
;;  (local $3 i32)
;;  (local $4 f32)
;;  (local $5 i32)
;;  (local $6 i32)
;;  (local $7 i32)
;;  (local $8 f32)
;;  (local $9 i32)
;;  (local $10 f32)
;;  (local $11 i32) ;; Previous (local $11 (tuple i32 f32))'s first element
;;  (local $12 f32) ;; Previous (local $11 (tuple i32 f32))'s second element
;;  (local $13 i32) ;; Previous (local $12 i32)

;; We parse this binary again into Binaryen IR, roundtripping the original
;; binary. Locals $14 and $15 are added for stacky IR resolving during binary
;; reading process.
;; RUN: wasm-opt -all -g --roundtrip %s.wasm -S -o - | filecheck %s --check-prefix=ROUNDTRIP
;; ROUNDTRIP:      (func $test
;; ROUNDTRIP-NEXT:  (local $0 i32)
;; ROUNDTRIP-NEXT:  (local $1 i32)
;; ROUNDTRIP-NEXT:  (local $2 i32)
;; ROUNDTRIP-NEXT:  (local $3 i32)
;; ROUNDTRIP-NEXT:  (local $4 f32)
;; ROUNDTRIP-NEXT:  (local $5 i32)
;; ROUNDTRIP-NEXT:  (local $6 i32)
;; ROUNDTRIP-NEXT:  (local $7 i32)
;; ROUNDTRIP-NEXT:  (local $8 f32)
;; ROUNDTRIP-NEXT:  (local $9 i32)
;; ROUNDTRIP-NEXT:  (local $10 f32)
;; ROUNDTRIP-NEXT:  (local $scratch i32)
;; ROUNDTRIP-NEXT:  (local $12 f32)
;; ROUNDTRIP-NEXT:  (local $scratch_12 i32)
;; ROUNDTRIP-NEXT:  (local $scratch_14 (tuple i32 f32))
;; ROUNDTRIP-NEXT:  (local $scratch_15 i32)

;; We can see that we don't reorder the locals during the process and the
;; original list of locals, local $0~$10, is untouched, to NOT invalidate DWARF
;; info.