[DWARF5] Added support for .debug_macro.dwo section in llvm-dwarfdump

This patch extends the parsing and dumping support of llvm-dwarfdump
for debug_macro.dwo section.

Following forms are supported:

 - DW_MACRO_define
 - DW_MACRO_undef
 - DW_MACRO_start_file
 - DW_MACRO_end_file
 - DW_MACRO_define_strx
 - DW_MACRO_undef_strx
 - DW_MACRO_define_strp
 - DW_MACRO_undef_strp

Reviewed by: ikudrin, dblaikie

Differential Revision: https://reviews.llvm.org/D78500
This commit is contained in:
Sourabh Singh Tomar 2020-05-29 23:57:35 +05:30
parent d2befc6633
commit e7102eed20
5 changed files with 141 additions and 5 deletions

View File

@ -72,6 +72,7 @@ class DWARFContext : public DIContext {
DWARFUnitVector DWOUnits;
std::unique_ptr<DWARFDebugAbbrev> AbbrevDWO;
std::unique_ptr<DWARFDebugMacro> MacinfoDWO;
std::unique_ptr<DWARFDebugMacro> MacroDWO;
/// The maximum DWARF version of all units.
unsigned MaxVersion = 0;
@ -110,8 +111,8 @@ class DWARFContext : public DIContext {
enum MacroSecType {
MacinfoSection,
MacinfoDwoSection,
MacroSection
// FIXME: Add support for.debug_macro.dwo section.
MacroSection,
MacroDwoSection
};
public:
@ -291,6 +292,9 @@ public:
/// Get a pointer to the parsed DebugMacro information object.
const DWARFDebugMacro *getDebugMacro();
/// Get a pointer to the parsed DebugMacroDWO information object.
const DWARFDebugMacro *getDebugMacroDWO();
/// Get a reference to the parsed accelerator table object.
const DWARFDebugNames &getDebugNames();
@ -319,6 +323,9 @@ public:
DataExtractor getStringExtractor() const {
return DataExtractor(DObj->getStrSection(), false, 0);
}
DataExtractor getStringDWOExtractor() const {
return DataExtractor(DObj->getStrDWOSection(), false, 0);
}
DataExtractor getLineStringExtractor() const {
return DataExtractor(DObj->getLineStrSection(), false, 0);
}

View File

@ -48,6 +48,7 @@ public:
virtual const DWARFSection &getRangesSection() const { return Dummy; }
virtual const DWARFSection &getRnglistsSection() const { return Dummy; }
virtual const DWARFSection &getMacroSection() const { return Dummy; }
virtual StringRef getMacroDWOSection() const { return ""; }
virtual StringRef getMacinfoSection() const { return ""; }
virtual StringRef getMacinfoDWOSection() const { return ""; }
virtual const DWARFSection &getPubnamesSection() const { return Dummy; }

View File

@ -264,9 +264,13 @@ std::unique_ptr<DWARFDebugMacro>
DWARFContext::parseMacroOrMacinfo(MacroSecType SectionType) {
auto Macro = std::make_unique<DWARFDebugMacro>();
auto ParseAndDump = [&](DWARFDataExtractor &Data, bool IsMacro) {
// FIXME: Add support for debug_macro.dwo section.
if (Error Err = IsMacro ? Macro->parseMacro(compile_units(),
getStringExtractor(), Data)
if (Error Err = IsMacro ? Macro->parseMacro(SectionType == MacroSection
? compile_units()
: dwo_compile_units(),
SectionType == MacroSection
? getStringExtractor()
: getStringDWOExtractor(),
Data)
: Macro->parseMacinfo(Data)) {
RecoverableErrorHandler(std::move(Err));
Macro = nullptr;
@ -289,6 +293,11 @@ DWARFContext::parseMacroOrMacinfo(MacroSecType SectionType) {
ParseAndDump(Data, /*IsMacro=*/true);
break;
}
case MacroDwoSection: {
DWARFDataExtractor Data(DObj->getMacroDWOSection(), isLittleEndian(), 0);
ParseAndDump(Data, /*IsMacro=*/true);
break;
}
}
return Macro;
}
@ -461,6 +470,12 @@ void DWARFContext::dump(
Macro->dump(OS);
}
if (shouldDump(Explicit, ".debug_macro.dwo", DIDT_ID_DebugMacro,
DObj->getMacroDWOSection())) {
if (auto MacroDWO = getDebugMacroDWO())
MacroDWO->dump(OS);
}
if (shouldDump(Explicit, ".debug_macinfo", DIDT_ID_DebugMacro,
DObj->getMacinfoSection())) {
if (auto Macinfo = getDebugMacinfo())
@ -845,6 +860,12 @@ const DWARFDebugMacro *DWARFContext::getDebugMacro() {
return Macro.get();
}
const DWARFDebugMacro *DWARFContext::getDebugMacroDWO() {
if (!MacroDWO)
MacroDWO = parseMacroOrMacinfo(MacroDwoSection);
return MacroDWO.get();
}
const DWARFDebugMacro *DWARFContext::getDebugMacinfo() {
if (!Macinfo)
Macinfo = parseMacroOrMacinfo(MacinfoSection);
@ -1534,6 +1555,7 @@ class DWARFObjInMemory final : public DWARFObject {
StringRef StrSection;
StringRef MacinfoSection;
StringRef MacinfoDWOSection;
StringRef MacroDWOSection;
StringRef AbbrevDWOSection;
StringRef StrDWOSection;
StringRef CUIndexSection;
@ -1554,6 +1576,7 @@ class DWARFObjInMemory final : public DWARFObject {
.Case("debug_str", &StrSection)
.Case("debug_macinfo", &MacinfoSection)
.Case("debug_macinfo.dwo", &MacinfoDWOSection)
.Case("debug_macro.dwo", &MacroDWOSection)
.Case("debug_abbrev.dwo", &AbbrevDWOSection)
.Case("debug_str.dwo", &StrDWOSection)
.Case("debug_cu_index", &CUIndexSection)
@ -1872,6 +1895,7 @@ public:
return RnglistsSection;
}
const DWARFSection &getMacroSection() const override { return MacroSection; }
StringRef getMacroDWOSection() const override { return MacroDWOSection; }
StringRef getMacinfoSection() const override { return MacinfoSection; }
StringRef getMacinfoDWOSection() const override { return MacinfoDWOSection; }
const DWARFSection &getPubnamesSection() const override { return PubnamesSection; }

View File

@ -0,0 +1,36 @@
## This test checks that llvm-dwarfdump can dump debug_macro.dwo
## section containing DW_MACRO_*_strp forms present in a dwo object.
# RUN: llvm-mc -triple x86_64-unknown-linux -filetype=obj %s -o -| \
# RUN: llvm-dwarfdump -debug-macro - | FileCheck -strict-whitespace -match-full-lines %s
# CHECK:.debug_macro.dwo contents:
# CHECK-NEXT:0x00000000:
# CHECK-NEXT:macro header: version = 0x0005, flags = 0x02, debug_line_offset = 0x0000
# CHECK-NEXT:DW_MACRO_start_file - lineno: 0 filenum: 0
# CHECK-NEXT: DW_MACRO_define_strp - lineno: 1 macro: DWARF_VERSION 5
# CHECK-NEXT: DW_MACRO_undef_strp - lineno: 4 macro: DWARF_VERSION
# CHECK-NEXT:DW_MACRO_end_file
.section .debug_macro.dwo,"e",@progbits
.Lcu_macro_begin0:
.short 5 # Macro information version
.byte 2 # Flags: 32 bit, debug_line_offset present
.long 0 # debug_line_offset
.byte 3 # DW_MACRO_start_file
.byte 0 # Line Number
.byte 0 # File Number
.byte 5 # DW_MACRO_define_strp
.byte 1 # Line Number
.long .Linfo_string0-.debug_str.dwo # Macro String
.byte 6 # DW_MACRO_undef_strp
.byte 4 # Line Number
.long .Linfo_string1-.debug_str.dwo # Macro String
.byte 4 # DW_MACRO_end_file
.byte 0 # End Of Macro List Mark
.section .debug_str.dwo,"eMS",@progbits,1
.Linfo_string0:
.asciz "DWARF_VERSION 5"
.Linfo_string1:
.asciz "DWARF_VERSION"

View File

@ -0,0 +1,68 @@
## This test checks that llvm-dwarfdump can dump debug_macro.dwo
## section containing DW_MACRO_*_strx forms present in a dwo object.
# RUN: llvm-mc -triple x86_64-unknown-linux -filetype=obj %s -o -| \
# RUN: llvm-dwarfdump -debug-macro - | FileCheck -strict-whitespace -match-full-lines %s
# CHECK:.debug_macro.dwo contents:
# CHECK-NEXT:0x00000000:
# CHECK-NEXT:macro header: version = 0x0005, flags = 0x02, debug_line_offset = 0x0000
# CHECK-NEXT:DW_MACRO_start_file - lineno: 0 filenum: 0
# CHECK-NEXT: DW_MACRO_define_strx - lineno: 1 macro: DWARF_VERSION 5
# CHECK-NEXT: DW_MACRO_undef_strx - lineno: 4 macro: DWARF_VERSION
# CHECK-NEXT:DW_MACRO_end_file
.section .debug_macro.dwo,"e",@progbits
.Lcu_macro_begin0:
.short 5 # Macro information version
.byte 2 # Flags: 32 bit, debug_line_offset present
.long 0 # debug_line_offset
.byte 3 # DW_MACRO_start_file
.byte 0 # Line Number
.byte 0 # File Number
.byte 11 # DW_MACRO_define_strx
.byte 1 # Line Number
.byte 0 # Macro String Index
.byte 12 # DW_MACRO_undef_strx
.byte 4 # Line Number
.byte 1 # Macro String Index
.byte 4 # DW_MACRO_end_file
.byte 0 # End Of Macro List Mark
.section .debug_str_offsets.dwo,"e",@progbits
.long .Lcu_str_off_end0-.Lcu_str_off_start0 # Unit length
.short 5 # Version
.short 0 # Padding
.Lcu_str_off_start0:
.long .Linfo_string0-.debug_str.dwo
.long .Linfo_string1-.debug_str.dwo
.Lcu_str_off_end0:
.section .debug_str.dwo,"eMS",@progbits,1
.Linfo_string0:
.asciz "DWARF_VERSION 5"
.Linfo_string1:
.asciz "DWARF_VERSION"
.section .debug_info.dwo,"e",@progbits
.long .Ldebug_info_dwo_end0-.Ldebug_info_dwo_start0 # Length of Unit
.Ldebug_info_dwo_start0:
.short 5 # DWARF version number
.byte 5 # DWARF Unit Type
.byte 8 # Address Size (in bytes)
.long 0 # Offset Into Abbrev. Section
.quad 1536875774479801980
.byte 1 # Abbrev [1] 0x14:0x1a DW_TAG_compile_unit
.long .Lcu_macro_begin0-.debug_macro.dwo # DW_AT_macros
.byte 0 # End Of Children Mark
.Ldebug_info_dwo_end0:
.section .debug_abbrev.dwo,"e",@progbits
.byte 1 # Abbreviation Code
.byte 17 # DW_TAG_compile_unit
.byte 0 # DW_CHILDREN_no
.byte 121 # DW_AT_macros
.byte 23 # DW_FORM_sec_offset
.byte 0 # EOM(1)
.byte 0 # EOM(2)
.byte 0 # EOM(3)