File: dwarf5-split-dwarf4-monolithic.test

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (299 lines) | stat: -rw-r--r-- 13,594 bytes parent folder | download
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
# REQUIRES: system-linux

; RUN: rm -rf %t
; RUN: mkdir %t
; RUN: cd %t

# RUN: llvm-mc -dwarf-version=5 -filetype=obj -triple x86_64-unknown-linux -split-dwarf-file=main.dwo %p/Inputs/dwarf5-split-dwarf4-monolithic-main.s -o main.o
# RUN: llvm-mc -dwarf-version=4 -filetype=obj -triple x86_64-unknown-linux %p/Inputs/dwarf5-dwarf4-monolithic-helper0.s -o helper0.o
# RUN: llvm-mc -dwarf-version=5 -filetype=obj -triple x86_64-unknown-linux -split-dwarf-file=helper1.dwo %p/Inputs/dwarf5-split-dwarf4-monolithic-helper1.s -o helper1.o
# RUN: llvm-mc -dwarf-version=4 -filetype=obj -triple x86_64-unknown-linux %p/Inputs/dwarf5-dwarf4-monolithic-helper2.s -o helper2.o
# RUN: %clang %cflags -dwarf-5 main.o helper0.o helper1.o helper2.o -o main.exe -Wl,-q
# RUN: llvm-bolt --always-convert-to-ranges main.exe -o main.bolt --update-debug-sections
# RUN: llvm-dwarfdump --show-form --verbose --debug-info main.exe | FileCheck --check-prefix=PRECHECK %s
# RUN: llvm-dwarfdump --show-form --verbose --debug-line main.exe | FileCheck --check-prefix=PRECHECK-LINE %s
# RUN: llvm-dwarfdump --show-form --verbose --debug-addr main.bolt >  boltout.txt
# RUN: llvm-dwarfdump --show-form --verbose --debug-info main.bolt >> boltout.txt
# RUN: cat boltout.txt | FileCheck --check-prefix=POSTCHECK %s
# RUN: llvm-dwarfdump --show-form --verbose --debug-info main.dwo.dwo | FileCheck --check-prefix=POSTCHECK-DWO-MAIN %s
# RUN: llvm-dwarfdump --show-form --verbose --debug-info helper1.dwo.dwo | FileCheck --check-prefix=POSTCHECK-DWO-HELPER1 %s
# RUN: llvm-dwarfdump --show-form --verbose --debug-line main.bolt | FileCheck --check-prefix=POSTCHECK-LINE %s


# Check BOLT handles monolithic mix of DWARF4 and DWARF5.

# main.cpp
# PRECHECK: version = 0x0005
# PRECHECK: DW_TAG_skeleton_unit
# PRECHECK-NEXT: DW_AT_stmt_list
# PRECHECK-NEXT: DW_AT_str_offsets_base
# PRECHECK-NEXT: DW_AT_comp_dir
# PRECHECK-NEXT: DW_AT_GNU_pubnames [DW_FORM_flag_present] (true)
# PRECHECK-NEXT: DW_AT_dwo_name [DW_FORM_strx1]  (indexed (00000001) string = "main.dwo")
# PRECHECK-NEXT: DW_AT_low_pc
# PRECHECK-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x0) rangelist = 0x00000010
# PRECHECK-NEXT: [0x
# PRECHECK-NEXT: [0x
# PRECHECK-NEXT: DW_AT_addr_base
# PRECHECK-NEXT: DW_AT_rnglists_base

# helper0.cpp
# PRECHECK: version = 0x0004
# PRECHECK: DW_TAG_compile_unit
# PRECHECK-NEXT: DW_AT_producer
# PRECHECK-NEXT: DW_AT_language
# PRECHECK-NEXT: DW_AT_name
# PRECHECK-NEXT: DW_AT_stmt_list
# PRECHECK-NEXT: DW_AT_comp_dir
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addr]
# PRECHECK-NEXT: DW_AT_high_pc
# PRECHECK: DW_TAG_subprogram [7]
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addr]
# PRECHECK-NEXT: DW_AT_high_pc
# PRECHECK: DW_TAG_variable [9]
# PRECHECK-NEXT: DW_AT_location [DW_FORM_sec_offset] (0x00000000:
# PRECHECK: DW_TAG_inlined_subroutine [10]
# PRECHECK-NEXT: DW_AT_abstract_origin
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addr]
# PRECHECK-NEXT: DW_AT_high_pc

# helper1.cpp
# PRECHECK: version = 0x0005
# PRECHECK: DW_TAG_skeleton_unit [1]
# PRECHECK-NEXT: DW_AT_stmt_list
# PRECHECK-NEXT: DW_AT_str_offsets_base
# PRECHECK-NEXT: DW_AT_comp_dir
# PRECHECK-NEXT: DW_AT_GNU_pubnames
# PRECHECK-NEXT: DW_AT_dwo_name [DW_FORM_strx1]  (indexed (00000001) string = "helper1.dwo")
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addrx]  (indexed (00000001) address
# PRECHECK-NEXT: DW_AT_high_pc [DW_FORM_data4]
# PRECHECK-NEXT: DW_AT_addr_base

# helper2.cpp
# PRECHECK: version = 0x0004
# PRECHECK: DW_TAG_compile_unit [1] *
# PRECHECK-NEXT: DW_AT_producer
# PRECHECK-NEXT: DW_AT_language
# PRECHECK-NEXT: DW_AT_name
# PRECHECK-NEXT: DW_AT_stmt_list
# PRECHECK-NEXT: DW_AT_comp_dir
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addr]
# PRECHECK-NEXT: DW_AT_high_pc [DW_FORM_data4]
# PRECHECK: DW_TAG_subprogram [7]
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addr]
# PRECHECK-NEXT: DW_AT_high_pc [DW_FORM_data4]
# PRECHECK: DW_TAG_variable [9]
# PRECHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]
# PRECHECK: DW_TAG_inlined_subroutine [10]
# PRECHECK-NEXT: DW_AT_abstract_origin
# PRECHECK-NEXT: DW_AT_low_pc [DW_FORM_addr]
# PRECHECK-NEXT: DW_AT_high_pc

# Checking debug line.

# PRECHECK-LINE: debug_line[
# PRECHECK-LINE: version: 5
# PRECHECK-LINE: include_directories[  0] =  .debug_line_str[0x[[#%.8x,LINE:]]] = "."
# PRECHECK-LINE-NEXT: file_names[  0]:
# PRECHECK-LINE-NEXT: name:  .debug_line_str[0x[[#%.8x,LINE:]]] = "main.cpp"
# PRECHECK-LINE-NEXT: dir_index: 0
# PRECHECK-LINE-NEXT: md5_checksum: e3a18fae8565a087d09d6076b542cdab

# PRECHECK-LINE: debug_line[
# PRECHECK-LINE: version: 4
# PRECHECK-LINE: include_directories[  1] = "/test"
# PRECHECK-LINE-NEXT: file_names[  1]:
# PRECHECK-LINE-NEXT: name: "helper0.cpp"
# PRECHECK-LINE-NEXT: dir_index: 1
# PRECHECK-LINE-NEXT: mod_time:
# PRECHECK-LINE-NEXT: length:

# PRECHECK-LINE: debug_line[
# PRECHECK-LINE: version: 5
# PRECHECK-LINE: include_directories[  0] =  .debug_line_str[0x[[#%.8x,LINE:]]] = "."
# PRECHECK-LINE-NEXT: file_names[  0]:
# PRECHECK-LINE-NEXT: name:  .debug_line_str[0x[[#%.8x,LINE:]]] = "helper1.cpp"
# PRECHECK-LINE-NEXT: dir_index: 0
# PRECHECK-LINE-NEXT: md5_checksum: e6dbd773fdf80bfea332cdf8284cddce


# PRECHECK-LINE: debug_line[
# PRECHECK-LINE: version: 4
# PRECHECK-LINE: include_directories[  1] = "/test"
# PRECHECK-LINE-NEXT: file_names[  1]:
# PRECHECK-LINE-NEXT: name: "helper2.cpp"
# PRECHECK-LINE-NEXT: dir_index: 1
# PRECHECK-LINE-NEXT: mod_time:
# PRECHECK-LINE-NEXT: length:


# POST BOLT.

# POSTCHECK: Addrs: [
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR1:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR2:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR3:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR4:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR5:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR6:]]

# POSTCHECK: Addrs: [
# POSTCHECK-NEXT: 0x[[#%.16x,ADDRB:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDRB1:]]
# POSTCHECK-NEXT: 0x[[#%.16x,ADDRB2:]]


# main.cpp
# POSTCHECK: version = 0x0005
# POSTCHECK: DW_AT_stmt_list [DW_FORM_sec_offset]  (0x00000000)
# POSTCHECK-NEXT: DW_AT_str_offsets_base [DW_FORM_sec_offset] (0x00000008)
# POSTCHECK-NEXT: DW_AT_comp_dir [DW_FORM_strx1]  (indexed (00000000) string = ".")
# POSTCHECK-NEXT: DW_AT_GNU_pubnames [DW_FORM_flag_present] (true)
# POSTCHECK-NEXT: DW_AT_dwo_name [DW_FORM_strx1]  (indexed (00000001) string = "main.dwo.dwo")
# POSTCHECK-NEXT: DW_AT_low_pc
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x0)
# POSTCHECK-NEXT: [0x[[#ADDR]], 0x[[#ADDR + 0x7]]
# POSTCHECK-NEXT: [0x[[#ADDR1]], 0x[[#ADDR1 + 0x51]]
# POSTCHECK-NEXT: DW_AT_addr_base [DW_FORM_sec_offset]
# POSTCHECK-NEXT: DW_AT_rnglists_base [DW_FORM_sec_offset]

# helper0.cpp
# POSTCHECK: version = 0x0004
# POSTCHECK: DW_TAG_compile_unit
# POSTCHECK-NEXT: DW_AT_producer
# POSTCHECK-NEXT: DW_AT_language
# POSTCHECK-NEXT: DW_AT_name
# POSTCHECK-NEXT: DW_AT_stmt_list
# POSTCHECK-NEXT: DW_AT_comp_dir
# POSTCHECK-NEXT: DW_AT_low_pc [DW_FORM_addr] (0x0000000000000000)
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x
# POSTCHECK: DW_TAG_subprogram [8]
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x
# POSTCHECK: DW_TAG_variable [10]
# POSTCHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x
# POSTCHECK-NEXT: [0x
# POSTCHECK: DW_TAG_inlined_subroutine [11]
# POSTCHECK-NEXT: DW_AT_abstract_origin
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x

# helper1.cpp
# POSTCHECK: version = 0x0005
# POSTCHECK: DW_TAG_skeleton_unit [12]
# POSTCHECK-NEXT: DW_AT_stmt_list [DW_FORM_sec_offset]  (0x000000fe)
# POSTCHECK-NEXT: DW_AT_str_offsets_base [DW_FORM_sec_offset] (0x00000018)
# POSTCHECK-NEXT: DW_AT_comp_dir [DW_FORM_strx1]  (indexed (00000000) string = ".")
# POSTCHECK-NEXT: DW_AT_GNU_pubnames [DW_FORM_flag_present] (true)
# POSTCHECK-NEXT: DW_AT_dwo_name [DW_FORM_strx1]  (indexed (00000001) string = "helper1.dwo.dwo")
# POSTCHECK-NEXT: DW_AT_low_pc [DW_FORM_addrx]  (indexed (00000002)
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x0)
# POSTCHECK-NEXT: [0x[[#ADDRB1]], 0x[[#ADDRB1 + 0x4]]
# POSTCHECK-NEXT: DW_AT_addr_base [DW_FORM_sec_offset]
# POSTCHECK-NEXT: DW_AT_rnglists_base [DW_FORM_sec_offset]

# helper2.cpp
# POSTCHECK: version = 0x0004
# POSTCHECK: DW_TAG_compile_unit [2] *
# POSTCHECK-NEXT: DW_AT_producer
# POSTCHECK-NEXT: DW_AT_language
# POSTCHECK-NEXT: DW_AT_name
# POSTCHECK-NEXT: DW_AT_stmt_list
# POSTCHECK-NEXT: DW_AT_comp_dir
# POSTCHECK-NEXT: DW_AT_low_pc [DW_FORM_addr] (0x0000000000000000)
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x
# POSTCHECK: DW_TAG_subprogram [8]
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x
# POSTCHECK: DW_TAG_variable [10]
# POSTCHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x
# POSTCHECK-NEXT: [0x
# POSTCHECK: DW_TAG_inlined_subroutine [11]
# POSTCHECK-NEXT: DW_AT_abstract_origin
# POSTCHECK-NEXT: DW_AT_ranges [DW_FORM_sec_offset]
# POSTCHECK-NEXT: [0x

# POSTCHECK-DWO-MAIN: version = 0x0005
# POSTCHECK-DWO-MAIN: DW_TAG_compile_unit
# POSTCHECK-DWO-MAIN: DW_TAG_subprogram [2]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x0) rangelist = 0x00000018
# POSTCHECK-DWO-MAIN-NEXT: [0x0000000000000000, 0x0000000000000007))
# POSTCHECK-DWO-MAIN: DW_TAG_subprogram [8]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x1) rangelist = 0x0000001c
# POSTCHECK-DWO-MAIN-NEXT: [0x0000000000000000, 0x0000000000000051))
# POSTCHECK-DWO-MAIN: DW_TAG_formal_parameter [9]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x0) loclist = 0x00000018:
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_base_addressx   (0x0000000000000001)
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_offset_pair     (0x0000000000000000, 0x0000000000000022): DW_OP_reg5 RDI
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_offset_pair     (0x0000000000000022, 0x0000000000000051): DW_OP_entry_value(DW_OP_reg5 RDI), DW_OP_stack_value)
# POSTCHECK-DWO-MAIN: DW_TAG_formal_parameter [9]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x1) loclist = 0x00000028:
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_base_addressx   (0x0000000000000001)
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_offset_pair     (0x0000000000000000, 0x0000000000000027): DW_OP_reg4 RSI
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_offset_pair     (0x0000000000000027, 0x0000000000000051): DW_OP_entry_value(DW_OP_reg4 RSI), DW_OP_stack_value)
# POSTCHECK-DWO-MAIN: DW_TAG_variable [10]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x2) loclist = 0x00000038:
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_base_addressx   (0x0000000000000002)
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_offset_pair     (0x0000000000000000, 0x0000000000000006): DW_OP_reg5 RDI
# POSTCHECK-DWO-MAIN-NEXT: DW_LLE_offset_pair     (0x0000000000000006, 0x0000000000000046): DW_OP_reg14 R14)
# POSTCHECK-DWO-MAIN: DW_TAG_inlined_subroutine [12]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_abstract_origin [DW_FORM_ref4]
# POSTCHECK-DWO-MAIN-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x2) rangelist = 0x00000020
# Encded as a pair. So it's offset from base address.
# POSTCHECK-DWO-MAIN-NEXT: [0x0000000000000003, 0x0000000000000007)
# POSTCHECK-DWO-MAIN-NEXT: [0x0000000000000013, 0x0000000000000019))

# POSTCHECK-DWO-HELPER1: version = 0x0005
# POSTCHECK-DWO-HELPER1: DW_TAG_subprogram [7]
# POSTCHECK-DWO-HELPER1-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x0) rangelist = 0x00000014
# POSTCHECK-DWO-HELPER1-NEXT: [0x0000000000000000, 0x0000000000000004))
# POSTCHECK-DWO-HELPER1: DW_TAG_variable [9]
# POSTCHECK-DWO-HELPER1-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x0) loclist = 0x00000010:
# POSTCHECK-DWO-HELPER1-NEXT: DW_LLE_base_addressx   (0x0000000000000001)
# POSTCHECK-DWO-HELPER1-NEXT: DW_LLE_offset_pair     (0x0000000000000000, 0x0000000000000003): DW_OP_reg5 RDI
# POSTCHECK-DWO-HELPER1-NEXT: DW_LLE_offset_pair     (0x0000000000000003, 0x0000000000000004): DW_OP_reg0 RAX)
# POSTCHECK-DWO-HELPER1: DW_TAG_inlined_subroutine [10]
# POSTCHECK-DWO-HELPER1-NEXT: DW_AT_abstract_origin
# POSTCHECK-DWO-HELPER1-NEXT: DW_AT_ranges [DW_FORM_rnglistx] (indexed (0x1) rangelist = 0x00000018
# POSTCHECK-DWO-HELPER1-NEXT: [0x0000000000000000, 0x0000000000000003))

# Checking debug line.

# POSTCHECK-LINE: debug_line[
# POSTCHECK-LINE: version: 5
# POSTCHECK-LINE: include_directories[  0] =  .debug_line_str[0x[[#%.8x,LINE:]]] = "."
# POSTCHECK-LINE-NEXT: file_names[  0]:
# POSTCHECK-LINE-NEXT: name:  .debug_line_str[0x[[#%.8x,LINE:]]] = "main.cpp"
# POSTCHECK-LINE-NEXT: dir_index: 0
# POSTCHECK-LINE-NEXT: md5_checksum: e3a18fae8565a087d09d6076b542cdab

# POSTCHECK-LINE: debug_line[
# POSTCHECK-LINE: version: 4
# POSTCHECK-LINE: include_directories[  1] = "/test"
# POSTCHECK-LINE-NEXT: file_names[  1]:
# POSTCHECK-LINE-NEXT: name: "helper0.cpp"
# POSTCHECK-LINE-NEXT: dir_index: 1
# POSTCHECK-LINE-NEXT: mod_time:
# POSTCHECK-LINE-NEXT: length:

# POSTCHECK-LINE: debug_line[
# POSTCHECK-LINE: version: 5
# POSTCHECK-LINE: include_directories[  0] =  .debug_line_str[0x[[#%.8x,LINE:]]] = "."
# POSTCHECK-LINE-NEXT: file_names[  0]:
# POSTCHECK-LINE-NEXT: name:  .debug_line_str[0x[[#%.8x,LINE:]]] = "helper1.cpp"
# POSTCHECK-LINE-NEXT: dir_index: 0
# POSTCHECK-LINE-NEXT: md5_checksum: e6dbd773fdf80bfea332cdf8284cddce

# POSTCHECK-LINE: debug_line[
# POSTCHECK-LINE: version: 4
# POSTCHECK-LINE: include_directories[  1] = "/test"
# POSTCHECK-LINE-NEXT: file_names[  1]:
# POSTCHECK-LINE-NEXT: name: "helper2.cpp"
# POSTCHECK-LINE-NEXT: dir_index: 1
# POSTCHECK-LINE-NEXT: mod_time:
# POSTCHECK-LINE-NEXT: length: