mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-04-12 20:48:17 +00:00
Introduce -brief command line option to llvm-dwarfdump
This patch introduces a new command line option, called brief, to llvm-dwarfdump. When -brief is used, the attribute forms for the .debug_info section will not be emitted to output. Patch by Spyridoula Gravani! rdar://problem/21474365 Differential Revision: https://reviews.llvm.org/D33867 llvm-svn: 304844
This commit is contained in:
parent
42258b84d2
commit
4c3b110004
@ -153,6 +153,7 @@ struct DIDumpOptions {
|
|||||||
DIDumpType DumpType = DIDT_All;
|
DIDumpType DumpType = DIDT_All;
|
||||||
bool DumpEH = false;
|
bool DumpEH = false;
|
||||||
bool SummarizeTypes = false;
|
bool SummarizeTypes = false;
|
||||||
|
bool Brief = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
class DIContext {
|
class DIContext {
|
||||||
|
@ -29,7 +29,7 @@ public:
|
|||||||
// VTable anchor.
|
// VTable anchor.
|
||||||
~DWARFCompileUnit() override;
|
~DWARFCompileUnit() override;
|
||||||
|
|
||||||
void dump(raw_ostream &OS);
|
void dump(raw_ostream &OS, DIDumpOptions DumpOpts);
|
||||||
|
|
||||||
static const DWARFSectionKind Section = DW_SECT_INFO;
|
static const DWARFSectionKind Section = DW_SECT_INFO;
|
||||||
};
|
};
|
||||||
|
@ -120,7 +120,8 @@ public:
|
|||||||
/// \param recurseDepth the depth to recurse to when dumping this DIE and its
|
/// \param recurseDepth the depth to recurse to when dumping this DIE and its
|
||||||
/// children.
|
/// children.
|
||||||
/// \param indent the number of characters to indent each line that is output.
|
/// \param indent the number of characters to indent each line that is output.
|
||||||
void dump(raw_ostream &OS, unsigned recurseDepth, unsigned indent = 0) const;
|
void dump(raw_ostream &OS, unsigned recurseDepth, unsigned indent = 0,
|
||||||
|
DIDumpOptions DumpOpts = DIDumpOptions()) const;
|
||||||
|
|
||||||
/// Extract the specified attribute from this DIE.
|
/// Extract the specified attribute from this DIE.
|
||||||
///
|
///
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
void DWARFCompileUnit::dump(raw_ostream &OS) {
|
void DWARFCompileUnit::dump(raw_ostream &OS, DIDumpOptions DumpOpts) {
|
||||||
OS << format("0x%08x", getOffset()) << ": Compile Unit:"
|
OS << format("0x%08x", getOffset()) << ": Compile Unit:"
|
||||||
<< " length = " << format("0x%08x", getLength())
|
<< " length = " << format("0x%08x", getLength())
|
||||||
<< " version = " << format("0x%04x", getVersion());
|
<< " version = " << format("0x%04x", getVersion());
|
||||||
@ -27,7 +27,7 @@ void DWARFCompileUnit::dump(raw_ostream &OS) {
|
|||||||
<< ")\n";
|
<< ")\n";
|
||||||
|
|
||||||
if (DWARFDie CUDie = getUnitDIE(false))
|
if (DWARFDie CUDie = getUnitDIE(false))
|
||||||
CUDie.dump(OS, -1U);
|
CUDie.dump(OS, -1U, 0, DumpOpts);
|
||||||
else
|
else
|
||||||
OS << "<compile unit can't be parsed!>\n\n";
|
OS << "<compile unit can't be parsed!>\n\n";
|
||||||
}
|
}
|
||||||
|
@ -221,14 +221,14 @@ void DWARFContext::dump(raw_ostream &OS, DIDumpOptions DumpOpts){
|
|||||||
if (DumpType == DIDT_All || DumpType == DIDT_Info) {
|
if (DumpType == DIDT_All || DumpType == DIDT_Info) {
|
||||||
OS << "\n.debug_info contents:\n";
|
OS << "\n.debug_info contents:\n";
|
||||||
for (const auto &CU : compile_units())
|
for (const auto &CU : compile_units())
|
||||||
CU->dump(OS);
|
CU->dump(OS, DumpOpts);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((DumpType == DIDT_All || DumpType == DIDT_InfoDwo) &&
|
if ((DumpType == DIDT_All || DumpType == DIDT_InfoDwo) &&
|
||||||
getNumDWOCompileUnits()) {
|
getNumDWOCompileUnits()) {
|
||||||
OS << "\n.debug_info.dwo contents:\n";
|
OS << "\n.debug_info.dwo contents:\n";
|
||||||
for (const auto &DWOCU : dwo_compile_units())
|
for (const auto &DWOCU : dwo_compile_units())
|
||||||
DWOCU->dump(OS);
|
DWOCU->dump(OS, DumpOpts);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((DumpType == DIDT_All || DumpType == DIDT_Types) && getNumTypeUnits()) {
|
if ((DumpType == DIDT_All || DumpType == DIDT_Types) && getNumTypeUnits()) {
|
||||||
|
@ -67,7 +67,8 @@ static void dumpRanges(raw_ostream &OS, const DWARFAddressRangesVector& Ranges,
|
|||||||
|
|
||||||
static void dumpAttribute(raw_ostream &OS, const DWARFDie &Die,
|
static void dumpAttribute(raw_ostream &OS, const DWARFDie &Die,
|
||||||
uint32_t *OffsetPtr, dwarf::Attribute Attr,
|
uint32_t *OffsetPtr, dwarf::Attribute Attr,
|
||||||
dwarf::Form Form, unsigned Indent) {
|
dwarf::Form Form, unsigned Indent,
|
||||||
|
DIDumpOptions DumpOpts) {
|
||||||
if (!Die.isValid())
|
if (!Die.isValid())
|
||||||
return;
|
return;
|
||||||
const char BaseIndent[] = " ";
|
const char BaseIndent[] = " ";
|
||||||
@ -78,13 +79,15 @@ static void dumpAttribute(raw_ostream &OS, const DWARFDie &Die,
|
|||||||
WithColor(OS, syntax::Attribute) << attrString;
|
WithColor(OS, syntax::Attribute) << attrString;
|
||||||
else
|
else
|
||||||
WithColor(OS, syntax::Attribute).get() << format("DW_AT_Unknown_%x", Attr);
|
WithColor(OS, syntax::Attribute).get() << format("DW_AT_Unknown_%x", Attr);
|
||||||
|
|
||||||
auto formString = FormEncodingString(Form);
|
if (!DumpOpts.Brief) {
|
||||||
if (!formString.empty())
|
auto formString = FormEncodingString(Form);
|
||||||
OS << " [" << formString << ']';
|
if (!formString.empty())
|
||||||
else
|
OS << " [" << formString << ']';
|
||||||
OS << format(" [DW_FORM_Unknown_%x]", Form);
|
else
|
||||||
|
OS << format(" [DW_FORM_Unknown_%x]", Form);
|
||||||
|
}
|
||||||
|
|
||||||
DWARFUnit *U = Die.getDwarfUnit();
|
DWARFUnit *U = Die.getDwarfUnit();
|
||||||
DWARFFormValue formValue(Form);
|
DWARFFormValue formValue(Form);
|
||||||
|
|
||||||
@ -301,8 +304,8 @@ void DWARFDie::getCallerFrame(uint32_t &CallFile, uint32_t &CallLine,
|
|||||||
CallDiscriminator = toUnsigned(find(DW_AT_GNU_discriminator), 0);
|
CallDiscriminator = toUnsigned(find(DW_AT_GNU_discriminator), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DWARFDie::dump(raw_ostream &OS, unsigned RecurseDepth,
|
void DWARFDie::dump(raw_ostream &OS, unsigned RecurseDepth, unsigned Indent,
|
||||||
unsigned Indent) const {
|
DIDumpOptions DumpOpts) const {
|
||||||
if (!isValid())
|
if (!isValid())
|
||||||
return;
|
return;
|
||||||
DataExtractor debug_info_data = U->getDebugInfoExtractor();
|
DataExtractor debug_info_data = U->getDebugInfoExtractor();
|
||||||
@ -322,10 +325,12 @@ void DWARFDie::dump(raw_ostream &OS, unsigned RecurseDepth,
|
|||||||
else
|
else
|
||||||
WithColor(OS, syntax::Tag).get().indent(Indent)
|
WithColor(OS, syntax::Tag).get().indent(Indent)
|
||||||
<< format("DW_TAG_Unknown_%x", getTag());
|
<< format("DW_TAG_Unknown_%x", getTag());
|
||||||
|
|
||||||
OS << format(" [%u] %c\n", abbrCode,
|
if (!DumpOpts.Brief)
|
||||||
AbbrevDecl->hasChildren() ? '*' : ' ');
|
OS << format(" [%u] %c", abbrCode,
|
||||||
|
AbbrevDecl->hasChildren() ? '*' : ' ');
|
||||||
|
OS << '\n';
|
||||||
|
|
||||||
// Dump all data in the DIE for the attributes.
|
// Dump all data in the DIE for the attributes.
|
||||||
for (const auto &AttrSpec : AbbrevDecl->attributes()) {
|
for (const auto &AttrSpec : AbbrevDecl->attributes()) {
|
||||||
if (AttrSpec.Form == DW_FORM_implicit_const) {
|
if (AttrSpec.Form == DW_FORM_implicit_const) {
|
||||||
@ -335,13 +340,13 @@ void DWARFDie::dump(raw_ostream &OS, unsigned RecurseDepth,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
dumpAttribute(OS, *this, &offset, AttrSpec.Attr, AttrSpec.Form,
|
dumpAttribute(OS, *this, &offset, AttrSpec.Attr, AttrSpec.Form,
|
||||||
Indent);
|
Indent, DumpOpts);
|
||||||
}
|
}
|
||||||
|
|
||||||
DWARFDie child = getFirstChild();
|
DWARFDie child = getFirstChild();
|
||||||
if (RecurseDepth > 0 && child) {
|
if (RecurseDepth > 0 && child) {
|
||||||
while (child) {
|
while (child) {
|
||||||
child.dump(OS, RecurseDepth-1, Indent+2);
|
child.dump(OS, RecurseDepth-1, Indent+2, DumpOpts);
|
||||||
child = child.getSibling();
|
child = child.getSibling();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
131
test/tools/llvm-dwarfdump/X86/brief.s
Normal file
131
test/tools/llvm-dwarfdump/X86/brief.s
Normal file
@ -0,0 +1,131 @@
|
|||||||
|
# RUN: llvm-mc %s -filetype obj -triple x86_64-apple-darwin -o - \
|
||||||
|
# RUN: | llvm-dwarfdump -debug-dump=info -brief - \
|
||||||
|
# RUN: | FileCheck %s
|
||||||
|
|
||||||
|
# CHECK: DW_TAG_compile_unit
|
||||||
|
# CHECK-NOT: DW_FORM
|
||||||
|
# CHECK: DW_AT
|
||||||
|
|
||||||
|
# This test is meant to verify that --brief hides DW_FORMs
|
||||||
|
# and abbreviation codes from .debug_info section.
|
||||||
|
|
||||||
|
|
||||||
|
.section __TEXT,__text,regular,pure_instructions
|
||||||
|
.section __DWARF,__debug_str,regular,debug
|
||||||
|
Linfo_string:
|
||||||
|
.asciz "basic.c" ## string offset=42
|
||||||
|
.section __DWARF,__debug_loc,regular,debug
|
||||||
|
Lsection_debug_loc:
|
||||||
|
.section __DWARF,__debug_abbrev,regular,debug
|
||||||
|
Lsection_abbrev:
|
||||||
|
.byte 1 ## Abbreviation Code
|
||||||
|
.byte 17 ## DW_TAG_compile_unit
|
||||||
|
.byte 0 ## DW_CHILDREN_no
|
||||||
|
.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
|
||||||
|
.byte 0 ## EOM(1)
|
||||||
|
.byte 0 ## EOM(2)
|
||||||
|
.byte 0 ## EOM(3)
|
||||||
|
.section __DWARF,__debug_info,regular,debug
|
||||||
|
Lsection_info:
|
||||||
|
Lcu_begin0:
|
||||||
|
.long 26 ## Length of Unit
|
||||||
|
.short 4 ## DWARF version number
|
||||||
|
Lset0 = Lsection_abbrev-Lsection_abbrev ## Offset Into Abbrev. Section
|
||||||
|
.long Lset0
|
||||||
|
.byte 8 ## Address Size (in bytes)
|
||||||
|
.byte 1 ## Abbrev [1] 0xb:0x13 DW_TAG_compile_unit
|
||||||
|
.long 0 ## DW_AT_producer
|
||||||
|
.short 12 ## DW_AT_language
|
||||||
|
.long 42 ## DW_AT_name
|
||||||
|
Lset1 = Lline_table_start0-Lsection_line ## DW_AT_stmt_list
|
||||||
|
.long Lset1
|
||||||
|
.long 50 ## DW_AT_comp_dir
|
||||||
|
.section __DWARF,__debug_ranges,regular,debug
|
||||||
|
Ldebug_range:
|
||||||
|
.section __DWARF,__debug_macinfo,regular,debug
|
||||||
|
Ldebug_macinfo:
|
||||||
|
Lcu_macro_begin0:
|
||||||
|
.byte 0 ## End Of Macro List Mark
|
||||||
|
.section __DWARF,__apple_names,regular,debug
|
||||||
|
Lnames_begin:
|
||||||
|
.long 1212240712 ## Header Magic
|
||||||
|
.short 1 ## Header Version
|
||||||
|
.short 0 ## Header Hash Function
|
||||||
|
.long 1 ## Header Bucket Count
|
||||||
|
.long 0 ## Header Hash Count
|
||||||
|
.long 12 ## Header Data Length
|
||||||
|
.long 0 ## HeaderData Die Offset Base
|
||||||
|
.long 1 ## HeaderData Atom Count
|
||||||
|
.short 1 ## DW_ATOM_die_offset
|
||||||
|
.short 6 ## DW_FORM_data4
|
||||||
|
.long -1 ## Bucket 0
|
||||||
|
.section __DWARF,__apple_objc,regular,debug
|
||||||
|
Lobjc_begin:
|
||||||
|
.long 1212240712 ## Header Magic
|
||||||
|
.short 1 ## Header Version
|
||||||
|
.short 0 ## Header Hash Function
|
||||||
|
.long 1 ## Header Bucket Count
|
||||||
|
.long 0 ## Header Hash Count
|
||||||
|
.long 12 ## Header Data Length
|
||||||
|
.long 0 ## HeaderData Die Offset Base
|
||||||
|
.long 1 ## HeaderData Atom Count
|
||||||
|
.short 1 ## DW_ATOM_die_offset
|
||||||
|
.short 6 ## DW_FORM_data4
|
||||||
|
.long -1 ## Bucket 0
|
||||||
|
.section __DWARF,__apple_namespac,regular,debug
|
||||||
|
Lnamespac_begin:
|
||||||
|
.long 1212240712 ## Header Magic
|
||||||
|
.short 1 ## Header Version
|
||||||
|
.short 0 ## Header Hash Function
|
||||||
|
.long 1 ## Header Bucket Count
|
||||||
|
.long 0 ## Header Hash Count
|
||||||
|
.long 12 ## Header Data Length
|
||||||
|
.long 0 ## HeaderData Die Offset Base
|
||||||
|
.long 1 ## HeaderData Atom Count
|
||||||
|
.short 1 ## DW_ATOM_die_offset
|
||||||
|
.short 6 ## DW_FORM_data4
|
||||||
|
.long -1 ## Bucket 0
|
||||||
|
.section __DWARF,__apple_types,regular,debug
|
||||||
|
Ltypes_begin:
|
||||||
|
.long 1212240712 ## Header Magic
|
||||||
|
.short 1 ## Header Version
|
||||||
|
.short 0 ## Header Hash Function
|
||||||
|
.long 1 ## Header Bucket Count
|
||||||
|
.long 0 ## Header Hash Count
|
||||||
|
.long 20 ## Header Data Length
|
||||||
|
.long 0 ## HeaderData Die Offset Base
|
||||||
|
.long 3 ## HeaderData Atom Count
|
||||||
|
.short 1 ## DW_ATOM_die_offset
|
||||||
|
.short 6 ## DW_FORM_data4
|
||||||
|
.short 3 ## DW_ATOM_die_tag
|
||||||
|
.short 5 ## DW_FORM_data2
|
||||||
|
.short 4 ## DW_ATOM_type_flags
|
||||||
|
.short 11 ## DW_FORM_data1
|
||||||
|
.long -1 ## Bucket 0
|
||||||
|
.section __DWARF,__apple_exttypes,regular,debug
|
||||||
|
Lexttypes_begin:
|
||||||
|
.long 1212240712 ## Header Magic
|
||||||
|
.short 1 ## Header Version
|
||||||
|
.short 0 ## Header Hash Function
|
||||||
|
.long 1 ## Header Bucket Count
|
||||||
|
.long 0 ## Header Hash Count
|
||||||
|
.long 12 ## Header Data Length
|
||||||
|
.long 0 ## HeaderData Die Offset Base
|
||||||
|
.long 1 ## HeaderData Atom Count
|
||||||
|
.short 7 ## DW_ATOM_ext_types
|
||||||
|
.short 6 ## DW_FORM_data4
|
||||||
|
.long -1 ## Bucket 0
|
||||||
|
|
||||||
|
.subsections_via_symbols
|
||||||
|
.section __DWARF,__debug_line,regular,debug
|
||||||
|
Lsection_line:
|
||||||
|
Lline_table_start0:
|
2
test/tools/llvm-dwarfdump/X86/lit.local.cfg
Normal file
2
test/tools/llvm-dwarfdump/X86/lit.local.cfg
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
if not 'X86' in config.root.targets:
|
||||||
|
config.unsupported = True
|
@ -84,6 +84,8 @@ static cl::opt<bool> Verify("verify", cl::desc("Verify the DWARF debug info"));
|
|||||||
static cl::opt<bool> Quiet("quiet",
|
static cl::opt<bool> Quiet("quiet",
|
||||||
cl::desc("Use with -verify to not emit to STDOUT."));
|
cl::desc("Use with -verify to not emit to STDOUT."));
|
||||||
|
|
||||||
|
static cl::opt<bool> Brief("brief", cl::desc("Print fewer low-level details"));
|
||||||
|
|
||||||
static void error(StringRef Filename, std::error_code EC) {
|
static void error(StringRef Filename, std::error_code EC) {
|
||||||
if (!EC)
|
if (!EC)
|
||||||
return;
|
return;
|
||||||
@ -101,6 +103,7 @@ static void DumpObjectFile(ObjectFile &Obj, Twine Filename) {
|
|||||||
DIDumpOptions DumpOpts;
|
DIDumpOptions DumpOpts;
|
||||||
DumpOpts.DumpType = DumpType;
|
DumpOpts.DumpType = DumpType;
|
||||||
DumpOpts.SummarizeTypes = SummarizeTypes;
|
DumpOpts.SummarizeTypes = SummarizeTypes;
|
||||||
|
DumpOpts.Brief = Brief;
|
||||||
DICtx->dump(outs(), DumpOpts);
|
DICtx->dump(outs(), DumpOpts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user