| # Test that parsing of line tables works reasonably. In this case the debug info |
| # does not have enough information for our heuristics to determine the path |
| # style, so we will just treat them as native host paths. |
| |
| # REQUIRES: lld, x86 |
| |
| # RUN: llvm-mc -triple x86_64-pc-linux %s -filetype=obj > %t.o |
| # RUN: ld.lld %t.o -o %t -z separate-code |
| # RUN: %lldb %t -s %S/Inputs/dir-separator-no-comp-dir-relative-name.lldbinit -o exit | FileCheck %s |
| |
| # CHECK-LABEL: image dump line-table a.c |
| # CHECK: Line table for foo{{.}}a.c |
| # CHECK-NEXT: 0x0000000000201000: foo{{.}}a.c:1 |
| # CHECK-NEXT: 0x0000000000201001: foo{{.}}b.c:1 |
| # CHECK-NEXT: 0x0000000000201002: foo{{.}}b.c:1 |
| # CHECK-EMPTY: |
| |
| # CHECK-LABEL: breakpoint set -f a.c -l 1 |
| # CHECK: Breakpoint 1: {{.*}}`_start, |
| |
| # CHECK-LABEL: breakpoint set -f foo/b.c -l 1 |
| # CHECK: Breakpoint 2: {{.*}}`_start + 1, |
| |
| .text |
| .globl _start |
| _start: |
| .file 1 "foo/a.c" |
| .loc 1 1 0 |
| nop |
| .file 2 "foo/b.c" |
| .loc 2 1 0 |
| nop |
| |
| .section .debug_str,"MS",@progbits,1 |
| .Linfo_string1: |
| .asciz "foo/a.c" |
| .section .debug_abbrev,"",@progbits |
| .byte 1 # Abbreviation Code |
| .byte 17 # DW_TAG_compile_unit |
| .byte 0 # DW_CHILDREN_no |
| .byte 19 # DW_AT_language |
| .byte 5 # DW_FORM_data2 |
| .byte 3 # DW_AT_name |
| .byte 14 # DW_FORM_strp |
| .byte 16 # DW_AT_stmt_list |
| .byte 23 # DW_FORM_sec_offset |
| .byte 0 # EOM(1) |
| .byte 0 # EOM(2) |
| .byte 0 # EOM(3) |
| .section .debug_info,"",@progbits |
| .Lcu_begin0: |
| .long .Lcu_end0-.Lcu_start0 # Length of Unit |
| .Lcu_start0: |
| .short 4 # DWARF version number |
| .long .debug_abbrev # Offset Into Abbrev. Section |
| .byte 8 # Address Size (in bytes) |
| .byte 1 # Abbrev [1] 0xb:0x1f DW_TAG_compile_unit |
| .short 12 # DW_AT_language |
| .long .Linfo_string1 # DW_AT_name |
| .long .Lline_table_start0 # DW_AT_stmt_list |
| .Lcu_end0: |
| .section .debug_line,"",@progbits |
| .Lline_table_start0: |