From bc41705cbca50d42e4575168e8d84705664bd94c Mon Sep 17 00:00:00 2001 From: David Blaikie Date: Sat, 22 Dec 2018 08:33:55 +0000 Subject: [PATCH] llvm-dwarfdump: Print the section name/number for addr_index attributes (addr attributes coming shortly) llvm-svn: 349996 --- include/llvm/DebugInfo/DWARF/DWARFFormValue.h | 2 ++ lib/DebugInfo/DWARF/DWARFFormValue.cpp | 15 ++++++++++++--- test/DebugInfo/X86/debug_addr.ll | 2 +- 3 files changed, 15 insertions(+), 4 deletions(-) diff --git a/include/llvm/DebugInfo/DWARF/DWARFFormValue.h b/include/llvm/DebugInfo/DWARF/DWARFFormValue.h index d6801b513a7..ed34d3c21de 100644 --- a/include/llvm/DebugInfo/DWARF/DWARFFormValue.h +++ b/include/llvm/DebugInfo/DWARF/DWARFFormValue.h @@ -75,6 +75,8 @@ public: bool isFormClass(FormClass FC) const; const DWARFUnit *getUnit() const { return U; } void dump(raw_ostream &OS, DIDumpOptions DumpOpts = DIDumpOptions()) const; + void dumpSectionedAddress(raw_ostream &OS, DIDumpOptions DumpOpts, + SectionedAddress SA) const; static void dumpAddressSection(const DWARFObject &Obj, raw_ostream &OS, DIDumpOptions DumpOpts, uint64_t SectionIndex); diff --git a/lib/DebugInfo/DWARF/DWARFFormValue.cpp b/lib/DebugInfo/DWARF/DWARFFormValue.cpp index c24782f12a2..90e8794c9d8 100644 --- a/lib/DebugInfo/DWARF/DWARFFormValue.cpp +++ b/lib/DebugInfo/DWARF/DWARFFormValue.cpp @@ -331,6 +331,14 @@ bool DWARFFormValue::extractValue(const DWARFDataExtractor &Data, return true; } +void DWARFFormValue::dumpSectionedAddress(raw_ostream &OS, + DIDumpOptions DumpOpts, + SectionedAddress SA) const { + OS << format("0x%016" PRIx64, SA.Address); + dumpAddressSection(U->getContext().getDWARFObj(), OS, DumpOpts, + SA.SectionIndex); +} + void DWARFFormValue::dumpAddressSection(const DWARFObject &Obj, raw_ostream &OS, DIDumpOptions DumpOpts, uint64_t SectionIndex) { @@ -365,9 +373,10 @@ void DWARFFormValue::dump(raw_ostream &OS, DIDumpOptions DumpOpts) const { AddrOS << format(" indexed (%8.8x) address = ", (uint32_t)UValue); if (U == nullptr) OS << ""; - else if (Optional A = U->getAddrOffsetSectionItem(UValue)) - AddrOS << format("0x%016" PRIx64, A->Address); - else + else if (Optional A = + U->getAddrOffsetSectionItem(UValue)) { + dumpSectionedAddress(AddrOS, DumpOpts, *A); + } else OS << ""; break; } diff --git a/test/DebugInfo/X86/debug_addr.ll b/test/DebugInfo/X86/debug_addr.ll index b50428a282c..64a79549fb1 100644 --- a/test/DebugInfo/X86/debug_addr.ll +++ b/test/DebugInfo/X86/debug_addr.ll @@ -32,7 +32,7 @@ ; DWARF5-NOT: DW_TAG_{{.*}} ; DWARF5: DW_AT_GNU_dwo_name{{.*}}test.dwo ; DWARF5: DW_AT_addr_base{{.*}}0x00000008 -; DWARF5: DW_AT_low_pc [DW_FORM_addrx] ( indexed (00000000) address = 0x0000000000000000) +; DWARF5: DW_AT_low_pc [DW_FORM_addrx] ( indexed (00000000) address = 0x0000000000000000 ".text") ; DWARF5: .debug_addr contents: ; DWARF5-NEXT: 0x00000000: Addr Section: length = 0x0000000c, version = 0x0005, addr_size = 0x04, seg_size = 0x00 ; DWARF5-NEXT: Addrs: [