[CodeView] Improve the line table dumper
[oota-llvm.git] / test / DebugInfo / COFF / multifile.ll
1 ; RUN: llc -mcpu=core2 -mtriple=i686-pc-win32 -O0 < %s | FileCheck --check-prefix=X86 %s
2 ; RUN: llc -mcpu=core2 -mtriple=i686-pc-win32 -o - -O0 < %s | llvm-mc -triple=i686-pc-win32 -filetype=obj | llvm-readobj -s -sr -codeview -section-symbols | FileCheck --check-prefix=OBJ32 %s
3 ; RUN: llc -mcpu=core2 -mtriple=x86_64-pc-win32 -O0 < %s | FileCheck --check-prefix=X64 %s
4 ; RUN: llc -mcpu=core2 -mtriple=x86_64-pc-win32 -o - -O0 < %s | llvm-mc -triple=x86_64-pc-win32 -filetype=obj | llvm-readobj -s -sr -codeview -section-symbols | FileCheck --check-prefix=OBJ64 %s
5
6 ; This LL file was generated by running clang on the following code:
7 ; D:\input.c:
8 ;  1 void g(void);
9 ;  2
10 ;  3 void f(void) {
11 ;  4 #line 1 "one.c"
12 ;  5   g();
13 ;  6 #line 2 "two.c"
14 ;  7   g();
15 ;  8 #line 7 "one.c"
16 ;  9   g();
17 ; 10 }
18
19 ; X86-LABEL: _f:
20 ; X86:      # BB
21 ; X86-NEXT: [[CALL_LINE_1:.*]]:{{$}}
22 ; X86:      calll   _g
23 ; X86-NEXT: [[CALL_LINE_2:.*]]:{{$}}
24 ; X86:      calll   _g
25 ; X86-NEXT: [[CALL_LINE_3:.*]]:{{$}}
26 ; X86:      calll   _g
27 ; X86-NEXT: [[RETURN_STMT:.*]]:
28 ; X86:      ret
29 ; X86-NEXT: [[END_OF_F:.*]]:
30 ;
31 ; X86-LABEL: .section        .debug$S,"dr"
32 ; X86-NEXT: .long   4
33 ; Symbol subsection
34 ; X86-NEXT: .long   241
35 ; X86-NEXT: .long [[F1_END:.*]]-[[F1_START:.*]]
36 ; X86-NEXT: [[F1_START]]:
37 ; X86-NEXT: .short [[PROC_SEGMENT_END:.*]]-[[PROC_SEGMENT_START:.*]]
38 ; X86-NEXT: [[PROC_SEGMENT_START]]:
39 ; X86-NEXT: .short  4423
40 ; X86-NEXT: .zero   12
41 ; X86-NEXT: .long [[END_OF_F]]-_f
42 ; X86-NEXT: .zero   12
43 ; X86-NEXT: .secrel32 _f
44 ; X86-NEXT: .secidx _f
45 ; X86-NEXT: .byte   0
46 ; X86-NEXT: .byte   102
47 ; X86-NEXT: .byte   0
48 ; X86-NEXT: [[PROC_SEGMENT_END]]:
49 ; X86-NEXT: .short  2
50 ; X86-NEXT: .short  4431
51 ; X86-NEXT: [[F1_END]]:
52 ; Padding
53 ; X86-NEXT: .zero   3
54 ; Line table
55 ; X86-NEXT: .long   242
56 ; X86-NEXT: .long [[F2_END:.*]]-[[F2_START:.*]]
57 ; X86-NEXT: [[F2_START]]:
58 ; X86-NEXT: .secrel32 _f
59 ; X86-NEXT: .secidx _f
60 ; X86-NEXT: .short 1
61 ; X86-NEXT: .long [[END_OF_F]]-_f
62 ; Segment for file 'D:\\one.c' begins
63 ; X86-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
64 ; X86-NEXT: .long   0
65 ; X86-NEXT: .long   1
66 ; X86-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
67 ; X86-NEXT: .long [[CALL_LINE_1]]-_f
68 ; X86-NEXT: .long   1
69 ; X86-NEXT: .short  0
70 ; X86-NEXT: .short  0
71 ; X86-NEXT: [[FILE_SEGMENT_END]]:
72 ; Segment for file 'D:\\two.c' begins
73 ; X86-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
74 ; X86-NEXT: .long   8
75 ; X86-NEXT: .long   1
76 ; X86-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
77 ; X86-NEXT: .long [[CALL_LINE_2]]-_f
78 ; X86-NEXT: .long   2
79 ; X86-NEXT: .short  0
80 ; X86-NEXT: .short  0
81 ; X86-NEXT: [[FILE_SEGMENT_END]]:
82 ; A new segment for file 'D:\\one.c' begins
83 ; X86-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
84 ; X86-NEXT: .long   0
85 ; X86-NEXT: .long   2
86 ; X86-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
87 ; X86-NEXT: .long [[CALL_LINE_3]]-_f
88 ; X86-NEXT: .long   7
89 ; X86-NEXT: .long [[RETURN_STMT]]-_f
90 ; X86-NEXT: .long   8
91 ; X86-NEXT: .short  0
92 ; X86-NEXT: .short  0
93 ; X86-NEXT: .short  0
94 ; X86-NEXT: .short  0
95 ; X86-NEXT: [[FILE_SEGMENT_END]]:
96 ; X86-NEXT: [[F2_END]]:
97 ; File index to string table offset subsection
98 ; X86-NEXT: .long   244
99 ; X86-NEXT: .long   16
100 ; X86-NEXT: .long   1
101 ; X86-NEXT: .long   0
102 ; X86-NEXT: .long   10
103 ; X86-NEXT: .long   0
104 ; String table
105 ; X86-NEXT: .long   243
106 ; X86-NEXT: .long   19
107 ; X86-NEXT: .byte   0
108 ; X86-NEXT: .ascii  "D:\\one.c"
109 ; X86-NEXT: .byte   0
110 ; X86-NEXT: .ascii  "D:\\two.c"
111 ; X86-NEXT: .byte   0
112 ; X86-NEXT: .zero   1
113
114 ; OBJ32:    Section {
115 ; OBJ32:      Name: .debug$S (2E 64 65 62 75 67 24 53)
116 ; OBJ32:      Characteristics [ (0x42100040)
117 ; OBJ32:      ]
118 ; OBJ32:      Relocations [
119 ; OBJ32-NEXT:   0x2C IMAGE_REL_I386_SECREL _f
120 ; OBJ32-NEXT:   0x30 IMAGE_REL_I386_SECTION _f
121 ; OBJ32-NEXT:   0x44 IMAGE_REL_I386_SECREL _f
122 ; OBJ32-NEXT:   0x48 IMAGE_REL_I386_SECTION _f
123 ; OBJ32-NEXT: ]
124 ; OBJ32:      Subsection [
125 ; OBJ32-NEXT:   Type: 0xF1
126 ; OBJ32-NOT:    ]
127 ; OBJ32:        ProcStart {
128 ; OBJ32-NEXT:     DisplayName: f
129 ; OBJ32-NEXT:     Section: _f
130 ; OBJ32-NEXT:     CodeSize: 0x10
131 ; OBJ32-NEXT:   }
132 ; OBJ32-NEXT:   ProcEnd
133 ; OBJ32-NEXT: ]
134 ; OBJ32:      FunctionLineTable [
135 ; OBJ32-NEXT:   Name: _f
136 ; OBJ32-NEXT:   Flags: 0x1
137 ; OBJ32-NEXT:   CodeSize: 0x10
138 ; OBJ32-NEXT:   FilenameSegment [
139 ; OBJ32-NEXT:     Filename: D:\one.c
140 ; OBJ32-NEXT:     +0x0 [
141 ; OBJ32-NEXT:       LineNumberStart: 1
142 ; OBJ32-NEXT:       LineNumberEndDelta: 0
143 ; OBJ32-NEXT:       IsStatement: No
144 ; OBJ32-NEXT:       ColStart: 0
145 ; OBJ32-NEXT:       ColEnd: 0
146 ; OBJ32-NEXT:     ]
147 ; OBJ32-NEXT:   ]
148 ; OBJ32-NEXT:   FilenameSegment [
149 ; OBJ32-NEXT:     Filename: D:\two.c
150 ; OBJ32-NEXT:     +0x5 [
151 ; OBJ32-NEXT:       LineNumberStart: 2
152 ; OBJ32-NEXT:       LineNumberEndDelta: 0
153 ; OBJ32-NEXT:       IsStatement: No
154 ; OBJ32-NEXT:       ColStart: 0
155 ; OBJ32-NEXT:       ColEnd: 0
156 ; OBJ32-NEXT:     ]
157 ; OBJ32-NEXT:   ]
158 ; OBJ32-NEXT:   FilenameSegment [
159 ; OBJ32-NEXT:     Filename: D:\one.c
160 ; OBJ32-NEXT:     +0xA [
161 ; OBJ32-NEXT:       LineNumberStart: 7
162 ; OBJ32-NEXT:       LineNumberEndDelta: 0
163 ; OBJ32-NEXT:       IsStatement: No
164 ; OBJ32-NEXT:       ColStart: 0
165 ; OBJ32-NEXT:       ColEnd: 0
166 ; OBJ32-NEXT:     ]
167 ; OBJ32-NEXT:     +0xF [
168 ; OBJ32-NEXT:       LineNumberStart: 8
169 ; OBJ32-NEXT:       LineNumberEndDelta: 0
170 ; OBJ32-NEXT:       IsStatement: No
171 ; OBJ32-NEXT:       ColStart: 0
172 ; OBJ32-NEXT:       ColEnd: 0
173 ; OBJ32-NEXT:     ]
174 ; OBJ32-NEXT:   ]
175 ; OBJ32-NEXT: ]
176
177 ; X64-LABEL: f:
178 ; X64-NEXT: .L{{.*}}:{{$}}
179 ; X64-NEXT: [[START:.*]]:{{$}}
180 ; X64:      # BB
181 ; X64:      subq    $40, %rsp
182 ; X64-NEXT: [[CALL_LINE_1:.*]]:{{$}}
183 ; X64:      callq   g
184 ; X64-NEXT: [[CALL_LINE_2:.*]]:{{$}}
185 ; X64:      callq   g
186 ; X64-NEXT: [[CALL_LINE_3:.*]]:{{$}}
187 ; X64:      callq   g
188 ; X64-NEXT: [[EPILOG_AND_RET:.*]]:
189 ; X64:      addq    $40, %rsp
190 ; X64-NEXT: ret
191 ; X64-NEXT: [[END_OF_F:.*]]:
192 ;
193 ; X64-LABEL: .section        .debug$S,"dr"
194 ; X64-NEXT: .long   4
195 ; Symbol subsection
196 ; X64-NEXT: .long   241
197 ; X64-NEXT: .long [[F1_END:.*]]-[[F1_START:.*]]
198 ; X64-NEXT: [[F1_START]]:
199 ; X64-NEXT: .short [[PROC_SEGMENT_END:.*]]-[[PROC_SEGMENT_START:.*]]
200 ; X64-NEXT: [[PROC_SEGMENT_START]]:
201 ; X64-NEXT: .short  4423
202 ; X64-NEXT: .zero   12
203 ; X64-NEXT: .long [[END_OF_F]]-f
204 ; X64-NEXT: .zero   12
205 ; X64-NEXT: .secrel32 f
206 ; X64-NEXT: .secidx f
207 ; X64-NEXT: .byte   0
208 ; X64-NEXT: .byte   102
209 ; X64-NEXT: .byte   0
210 ; X64-NEXT: [[PROC_SEGMENT_END]]:
211 ; X64-NEXT: .short  2
212 ; X64-NEXT: .short  4431
213 ; X64-NEXT: [[F1_END]]:
214 ; Padding
215 ; X64-NEXT: .zero   3
216 ; Line table
217 ; X64-NEXT: .long   242
218 ; X64-NEXT: .long [[F2_END:.*]]-[[F2_START:.*]]
219 ; X64-NEXT: [[F2_START]]:
220 ; X64-NEXT: .secrel32 f
221 ; X64-NEXT: .secidx f
222 ; X64-NEXT: .short 1
223 ; X64-NEXT: .long [[END_OF_F]]-f
224 ; Segment for file 'D:\\input.c' begins
225 ; X64-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
226 ; X64-NEXT: .long   0
227 ; X64-NEXT: .long   1
228 ; X64-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
229 ; X64-NEXT: .long [[START]]-f
230 ; X64-NEXT: .long   3
231 ; X64-NEXT: .short  0
232 ; X64-NEXT: .short  0
233 ; X64-NEXT: [[FILE_SEGMENT_END]]:
234 ; Segment for file 'D:\\one.c' begins
235 ; X64-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
236 ; X64-NEXT: .long   8
237 ; X64-NEXT: .long   1
238 ; X64-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
239 ; X64-NEXT: .long [[CALL_LINE_1]]-f
240 ; X64-NEXT: .long   1
241 ; X64-NEXT: .short  0
242 ; X64-NEXT: .short  0
243 ; X64-NEXT: [[FILE_SEGMENT_END]]:
244 ; Segment for file 'D:\\two.c' begins
245 ; X64-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
246 ; X64-NEXT: .long   16
247 ; X64-NEXT: .long   1
248 ; X64-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
249 ; X64-NEXT: .long [[CALL_LINE_2]]-f
250 ; X64-NEXT: .long   2
251 ; X64-NEXT: .short  0
252 ; X64-NEXT: .short  0
253 ; X64-NEXT: [[FILE_SEGMENT_END]]:
254 ; A new segment for file 'D:\\one.c' begins
255 ; X64-NEXT: [[FILE_SEGMENT_START:[^:]*]]:
256 ; X64-NEXT: .long   8
257 ; X64-NEXT: .long   2
258 ; X64-NEXT: .long [[FILE_SEGMENT_END:.*]]-[[FILE_SEGMENT_START]]
259 ; X64-NEXT: .long [[CALL_LINE_3]]-f
260 ; X64-NEXT: .long   7
261 ; X64-NEXT: .long [[EPILOG_AND_RET]]-f
262 ; X64-NEXT: .long   8
263 ; X64-NEXT: .short  0
264 ; X64-NEXT: .short  0
265 ; X64-NEXT: .short  0
266 ; X64-NEXT: .short  0
267 ; X64-NEXT: [[FILE_SEGMENT_END]]:
268 ; X64-NEXT: [[F2_END]]:
269 ; File index to string table offset subsection
270 ; X64-NEXT: .long   244
271 ; X64-NEXT: .long   24
272 ; X64-NEXT: .long   1
273 ; X64-NEXT: .long   0
274 ; X64-NEXT: .long   12
275 ; X64-NEXT: .long   0
276 ; X64-NEXT: .long   21
277 ; X64-NEXT: .long   0
278 ; String table
279 ; X64-NEXT: .long   243
280 ; X64-NEXT: .long   30
281 ; X64-NEXT: .byte   0
282 ; X64-NEXT: .ascii  "D:\\input.c"
283 ; X64-NEXT: .byte   0
284 ; X64-NEXT: .ascii  "D:\\one.c"
285 ; X64-NEXT: .byte   0
286 ; X64-NEXT: .ascii  "D:\\two.c"
287 ; X64-NEXT: .byte   0
288 ; X64-NEXT: .zero   2
289
290 ; OBJ64:    Section {
291 ; OBJ64:      Name: .debug$S (2E 64 65 62 75 67 24 53)
292 ; OBJ64:      Characteristics [ (0x42100040)
293 ; OBJ64:      ]
294 ; OBJ64:      Relocations [
295 ; OBJ64-NEXT:   0x2C IMAGE_REL_AMD64_SECREL f
296 ; OBJ64-NEXT:   0x30 IMAGE_REL_AMD64_SECTION f
297 ; OBJ64-NEXT:   0x44 IMAGE_REL_AMD64_SECREL f
298 ; OBJ64-NEXT:   0x48 IMAGE_REL_AMD64_SECTION f
299 ; OBJ64-NEXT: ]
300 ; OBJ64:      Subsection [
301 ; OBJ64-NEXT:   Type: 0xF1
302 ; OBJ64-NOT:    ]
303 ; OBJ64:        ProcStart {
304 ; OBJ64-NEXT:     DisplayName: f
305 ; OBJ64-NEXT:     Section: f
306 ; OBJ64-NEXT:     CodeSize: 0x18
307 ; OBJ64-NEXT:   }
308 ; OBJ64-NEXT:   ProcEnd
309 ; OBJ64-NEXT: ]
310 ; OBJ64:      FunctionLineTable [
311 ; OBJ64-NEXT:   Name: f
312 ; OBJ64-NEXT:   Flags: 0x1
313 ; OBJ64-NEXT:   CodeSize: 0x18
314 ; OBJ64-NEXT:   FilenameSegment [
315 ; OBJ64-NEXT:     Filename: D:\input.c
316 ; OBJ64-NEXT:     +0x0 [
317 ; OBJ64-NEXT:       LineNumberStart: 3
318 ; OBJ64-NEXT:       LineNumberEndDelta: 0
319 ; OBJ64-NEXT:       IsStatement: No
320 ; OBJ64-NEXT:       ColStart: 0
321 ; OBJ64-NEXT:       ColEnd: 0
322 ; OBJ64-NEXT:     ]
323 ; OBJ64-NEXT:   ]
324 ; OBJ64-NEXT:   FilenameSegment [
325 ; OBJ64-NEXT:     Filename: D:\one.c
326 ; OBJ64-NEXT:     +0x4 [
327 ; OBJ64-NEXT:       LineNumberStart: 1
328 ; OBJ64-NEXT:       LineNumberEndDelta: 0
329 ; OBJ64-NEXT:       IsStatement: No
330 ; OBJ64-NEXT:       ColStart: 0
331 ; OBJ64-NEXT:       ColEnd: 0
332 ; OBJ64-NEXT:     ]
333 ; OBJ64-NEXT:   ]
334 ; OBJ64-NEXT:   FilenameSegment [
335 ; OBJ64-NEXT:     Filename: D:\two.c
336 ; OBJ64-NEXT:     +0x9 [
337 ; OBJ64-NEXT:       LineNumberStart: 2
338 ; OBJ64-NEXT:       LineNumberEndDelta: 0
339 ; OBJ64-NEXT:       IsStatement: No
340 ; OBJ64-NEXT:       ColStart: 0
341 ; OBJ64-NEXT:       ColEnd: 0
342 ; OBJ64-NEXT:     ]
343 ; OBJ64-NEXT:   ]
344 ; OBJ64-NEXT:   FilenameSegment [
345 ; OBJ64-NEXT:     Filename: D:\one.c
346 ; OBJ64-NEXT:     +0xE [
347 ; OBJ64-NEXT:       LineNumberStart: 7
348 ; OBJ64-NEXT:       LineNumberEndDelta: 0
349 ; OBJ64-NEXT:       IsStatement: No
350 ; OBJ64-NEXT:       ColStart: 0
351 ; OBJ64-NEXT:       ColEnd: 0
352 ; OBJ64-NEXT:     ]
353 ; OBJ64-NEXT:     +0x13 [
354 ; OBJ64-NEXT:       LineNumberStart: 8
355 ; OBJ64-NEXT:       LineNumberEndDelta: 0
356 ; OBJ64-NEXT:       IsStatement: No
357 ; OBJ64-NEXT:       ColStart: 0
358 ; OBJ64-NEXT:       ColEnd: 0
359 ; OBJ64-NEXT:     ]
360 ; OBJ64-NEXT:   ]
361 ; OBJ64-NEXT: ]
362
363 ; Function Attrs: nounwind
364 define void @f() #0 !dbg !4 {
365 entry:
366   call void @g(), !dbg !12
367   call void @g(), !dbg !15
368   call void @g(), !dbg !18
369   ret void, !dbg !19
370 }
371
372 declare void @g() #1
373
374 attributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
375 attributes #1 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
376
377 !llvm.dbg.cu = !{!0}
378 !llvm.module.flags = !{!9, !10}
379 !llvm.ident = !{!11}
380
381 !0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.5 ", isOptimized: false, emissionKind: 0, file: !1, enums: !2, retainedTypes: !2, subprograms: !3, globals: !2, imports: !2)
382 !1 = !DIFile(filename: "<unknown>", directory: "D:\5C")
383 !2 = !{}
384 !3 = !{!4}
385 !4 = distinct !DISubprogram(name: "f", line: 3, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: false, scopeLine: 3, file: !5, scope: !6, type: !7, variables: !2)
386 !5 = !DIFile(filename: "input.c", directory: "D:\5C")
387 !6 = !DIFile(filename: "input.c", directory: "D:C")
388 !7 = !DISubroutineType(types: !8)
389 !8 = !{null}
390 !9 = !{i32 2, !"CodeView", i32 1}
391 !10 = !{i32 1, !"Debug Info Version", i32 3}
392 !11 = !{!"clang version 3.5 "}
393 !12 = !DILocation(line: 1, scope: !13)
394 !13 = !DILexicalBlockFile(discriminator: 0, file: !14, scope: !4)
395 !14 = !DIFile(filename: "one.c", directory: "D:\5C")
396 !15 = !DILocation(line: 2, scope: !16)
397 !16 = !DILexicalBlockFile(discriminator: 0, file: !17, scope: !4)
398 !17 = !DIFile(filename: "two.c", directory: "D:\5C")
399 !18 = !DILocation(line: 7, scope: !13)
400 !19 = !DILocation(line: 8, scope: !13)