[PATCH] D39542: [ELF] - Teach LLD to use information from .debug_str for error reporting.
Rafael Avila de Espindola via llvm-commits
llvm-commits at lists.llvm.org
Thu Nov 16 15:49:35 PST 2017
LGTM, thanks!
George Rimar via Phabricator <reviews at reviews.llvm.org> writes:
> grimar updated this revision to Diff 123143.
>
> https://reviews.llvm.org/D39542
>
> Files:
> ELF/GdbIndex.cpp
> ELF/GdbIndex.h
> test/ELF/conflict-debug-variable2.s
> test/ELF/gdb-index-noranges.s
>
> Index: test/ELF/gdb-index-noranges.s
> ===================================================================
> --- test/ELF/gdb-index-noranges.s
> +++ test/ELF/gdb-index-noranges.s
> @@ -0,0 +1,49 @@
> +# REQUIRES: x86
> +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t1.o
> +
> +## Input is reduced from following code and invocation:
> +## clang++ -gsplit-dwarf -c test.ii -o test.s -S
> +## clang version: 6.0.0 (trunk 318293)
> +##
> +## test.ii:
> +## int a;
> +##
> +## Debug information does not contain any address ranges.
> +## We crashed in that case. Check we don't.
> +# RUN: ld.lld --gdb-index %t1.o -o %t
> +
> +.section .debug_str,"MS", at progbits,1
> +.Lskel_string0:
> + .asciz "t.dwo"
> +.Lskel_string1:
> + .asciz "path"
> +
> +.section .debug_abbrev,"", at progbits
> + .byte 1 # Abbreviation Code
> + .byte 17 # DW_TAG_compile_unit
> + .byte 0 # DW_CHILDREN_no
> + .byte 16 # DW_AT_stmt_list
> + .byte 23 # DW_FORM_sec_offset
> + .ascii "\260B" # DW_AT_GNU_dwo_name
> + .byte 14 # DW_FORM_strp
> + .byte 27 # DW_AT_comp_dir
> + .byte 14 # DW_FORM_strp
> + .ascii "\261B" # DW_AT_GNU_dwo_id
> + .byte 7 # DW_FORM_data8
> + .ascii "\263B" # DW_AT_GNU_addr_base
> + .byte 23 # DW_FORM_sec_offset
> + .byte 0 # EOM(1)
> + .byte 0 # EOM(2)
> + .byte 0 # EOM(3)
> +
> +.section .debug_info,"", at progbits
> + .long 32 # Length of Unit
> + .short 4 # DWARF version number
> + .long .debug_abbrev # Offset Into Abbrev. Section
> + .byte 8 # Address Size (in bytes)
> + .byte 1 # Abbrev [1] 0xb:0x19 DW_TAG_compile_unit
> + .long 0 # DW_AT_stmt_list
> + .long .Lskel_string0 # DW_AT_GNU_dwo_name
> + .long .Lskel_string1 # DW_AT_comp_dir
> + .quad -3824446529333676116 # DW_AT_GNU_dwo_id
> + .long 0 # DW_AT_GNU_addr_base
> Index: test/ELF/conflict-debug-variable2.s
> ===================================================================
> --- test/ELF/conflict-debug-variable2.s
> +++ test/ELF/conflict-debug-variable2.s
> @@ -0,0 +1,160 @@
> +# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t.o
> +
> +# RUN: llvm-dwarfdump -v %t.o | FileCheck -check-prefix=INPUT %s
> +# INPUT: .debug_info contents:
> +# INPUT: DW_TAG_variable
> +# INPUT-NEXT: DW_AT_name [DW_FORM_strp] ( .debug_str[0x00000027] = "foo")
> +# INPUT-NEXT: DW_AT_type [DW_FORM_ref4] (cu + 0x0033 => {0x00000033} "int")
> +# INPUT-NEXT: DW_AT_external [DW_FORM_flag_present] (true)
> +# INPUT-NEXT: DW_AT_decl_file [DW_FORM_data1] ("/home/path/test.c")
> +# INPUT-NEXT: DW_AT_decl_line [DW_FORM_data1] (1)
> +# INPUT-NEXT: DW_AT_location [DW_FORM_exprloc] (DW_OP_addr 0x0)
> +# INPUT: DW_TAG_variable
> +# INPUT-NEXT: DW_AT_name [DW_FORM_strp] ( .debug_str[0x0000002f] = "bar")
> +# INPUT-NEXT: DW_AT_type [DW_FORM_ref4] (cu + 0x0033 => {0x00000033} "int")
> +# INPUT-NEXT: DW_AT_external [DW_FORM_flag_present] (true)
> +# INPUT-NEXT: DW_AT_decl_file [DW_FORM_data1] ("/home/path/test.c")
> +# INPUT-NEXT: DW_AT_decl_line [DW_FORM_data1] (2)
> +# INPUT-NEXT: DW_AT_location [DW_FORM_exprloc] (DW_OP_addr 0x0)
> +
> +## Check we use information from .debug_info in messages.
> +# RUN: not ld.lld %t.o %t.o -o %t 2>&1 | FileCheck %s
> +# CHECK: duplicate symbol: bar
> +# CHECK-NEXT: >>> defined at test.c:2
> +# CHECK-NEXT: >>> {{.*}}:(bar)
> +# CHECK-NEXT: >>> defined at test.c:2
> +# CHECK-NEXT: >>> {{.*}}:(.data+0x0)
> +# CHECK: duplicate symbol: foo
> +# CHECK-NEXT: >>> defined at test.c:1
> +# CHECK-NEXT: >>> {{.*}}:(foo)
> +# CHECK-NEXT: >>> defined at test.c:1
> +# CHECK-NEXT: >>> {{.*}}:(.bss+0x0)
> +
> +# Used reduced output from following code and clang
> +# version 6.0.0 (trunk 316661) to produce this input file:
> +# Source (test.c):
> +# int foo = 0;
> +# int bar = 1;
> +# Invocation: clang -g -S test.c
> +
> +.text
> +.file "test.c"
> +.file 1 "test.c"
> +
> +.type foo, at object
> +.bss
> +.globl foo
> +.p2align 2
> +foo:
> + .long 0
> + .size foo, 4
> +
> +.type bar, at object
> +.data
> +.globl bar
> +.p2align 2
> +bar:
> + .long 1
> + .size bar, 4
> +
> +.section .debug_str,"MS", at progbits,1
> +.Linfo_string0:
> + .asciz "clang version 6.0.0"
> +.Linfo_string1:
> + .asciz "test.c"
> +.Linfo_string2:
> + .asciz "/home/path/"
> +.Linfo_string3:
> + .asciz "foo"
> +.Linfo_string4:
> + .asciz "int"
> +.Linfo_string5:
> + .asciz "bar"
> +
> +.section .debug_abbrev,"", at progbits
> + .byte 1 # Abbreviation Code
> + .byte 17 # DW_TAG_compile_unit
> + .byte 1 # DW_CHILDREN_yes
> + .byte 37 # DW_AT_producer
> + .byte 14 # DW_FORM_strp
> + .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 27 # DW_AT_comp_dir
> + .byte 14 # DW_FORM_strp
> + .ascii "\264B" # DW_AT_GNU_pubnames
> + .byte 25 # DW_FORM_flag_present
> + .byte 0 # EOM(1)
> + .byte 0 # EOM(2)
> +
> + .byte 2 # Abbreviation Code
> + .byte 52 # DW_TAG_variable
> + .byte 0 # DW_CHILDREN_no
> + .byte 3 # DW_AT_name
> + .byte 14 # DW_FORM_strp
> + .byte 73 # DW_AT_type
> + .byte 19 # DW_FORM_ref4
> + .byte 63 # DW_AT_external
> + .byte 25 # DW_FORM_flag_present
> + .byte 58 # DW_AT_decl_file
> + .byte 11 # DW_FORM_data1
> + .byte 59 # DW_AT_decl_line
> + .byte 11 # DW_FORM_data1
> + .byte 2 # DW_AT_location
> + .byte 24 # DW_FORM_exprloc
> + .byte 0 # EOM(1)
> + .byte 0 # EOM(2)
> +
> + .byte 3 # Abbreviation Code
> + .byte 36 # DW_TAG_base_type
> + .byte 0 # DW_CHILDREN_no
> + .byte 3 # DW_AT_name
> + .byte 14 # DW_FORM_strp
> + .byte 62 # DW_AT_encoding
> + .byte 11 # DW_FORM_data1
> + .byte 11 # DW_AT_byte_size
> + .byte 11 # DW_FORM_data1
> + .byte 0 # EOM(1)
> + .byte 0 # EOM(2)
> + .byte 0 # EOM(3)
> +
> +.section .debug_info,"", at progbits
> +.Lcu_begin0:
> + .long 76 # Length of Unit
> + .short 4 # DWARF version number
> + .long .debug_abbrev # Offset Into Abbrev. Section
> + .byte 8 # Address Size (in bytes)
> +
> + .byte 1 # Abbrev [1] 0xb:0x45 DW_TAG_compile_unit
> + .long .Linfo_string0 # DW_AT_producer
> + .short 12 # DW_AT_language
> + .long .Linfo_string1 # DW_AT_name
> + .long 0 # DW_AT_stmt_list
> + .long .Linfo_string2 # DW_AT_comp_dir
> +
> + .byte 2 # Abbrev [2] 0x1e:0x15 DW_TAG_variable
> + .long .Linfo_string3 # DW_AT_name
> + .long 51 # DW_AT_type
> + .byte 1 # DW_AT_decl_file
> + .byte 1 # DW_AT_decl_line
> + .byte 9 # DW_AT_location
> + .byte 3
> + .quad foo
> +
> + .byte 3 # Abbrev [3] 0x33:0x7 DW_TAG_base_type
> + .long .Linfo_string4 # DW_AT_name
> + .byte 5 # DW_AT_encoding
> + .byte 4 # DW_AT_byte_size
> +
> + .byte 2 # Abbrev [2] 0x3a:0x15 DW_TAG_variable
> + .long .Linfo_string5 # DW_AT_name
> + .long 51 # DW_AT_type
> + .byte 1 # DW_AT_decl_file
> + .byte 2 # DW_AT_decl_line
> + .byte 9 # DW_AT_location
> + .byte 3
> + .quad bar
> + .byte 0 # End Of Children Mark
> Index: ELF/GdbIndex.h
> ===================================================================
> --- ELF/GdbIndex.h
> +++ ELF/GdbIndex.h
> @@ -30,6 +30,7 @@
> StringRef AbbrevSection;
> StringRef GnuPubNamesSection;
> StringRef GnuPubTypesSection;
> + StringRef StrSection;
>
> template <class RelTy>
> llvm::Optional<llvm::RelocAddrEntry> findAux(const InputSectionBase &Sec,
> @@ -47,9 +48,10 @@
> const llvm::DWARFSection &getLineSection() const override {
> return LineSection;
> }
> + StringRef getFileName() const override { return ""; }
> StringRef getCUIndexSection() const override { return ""; }
> StringRef getAbbrevSection() const override { return AbbrevSection; }
> - StringRef getStringSection() const override { return ""; }
> + StringRef getStringSection() const override { return StrSection; }
> StringRef getGnuPubNamesSection() const override {
> return GnuPubNamesSection;
> }
> Index: ELF/GdbIndex.cpp
> ===================================================================
> --- ELF/GdbIndex.cpp
> +++ ELF/GdbIndex.cpp
> @@ -44,6 +44,8 @@
> GnuPubNamesSection = toStringRef(Sec->Data);
> else if (Sec->Name == ".debug_gnu_pubtypes")
> GnuPubTypesSection = toStringRef(Sec->Data);
> + else if (Sec->Name == ".debug_str")
> + StrSection = toStringRef(Sec->Data);
> }
> }
>
More information about the llvm-commits
mailing list