llvm-dwarfdump: Support for debug_line.dwo section for file names for type units under fission.

llvm-svn: 202091
This commit is contained in:
David Blaikie 2014-02-24 23:58:54 +00:00
parent 6c834371d9
commit 5c7418b2ee
9 changed files with 53 additions and 15 deletions

View File

@ -107,6 +107,7 @@ enum DIDumpType {
DIDT_Types, DIDT_Types,
DIDT_TypesDwo, DIDT_TypesDwo,
DIDT_Line, DIDT_Line,
DIDT_LineDwo,
DIDT_Loc, DIDT_Loc,
DIDT_Ranges, DIDT_Ranges,
DIDT_Pubnames, DIDT_Pubnames,

View File

@ -136,6 +136,16 @@ void DWARFContext::dump(raw_ostream &OS, DIDumpType DumpType) {
} }
} }
if (DumpType == DIDT_All || DumpType == DIDT_LineDwo) {
OS << "\n.debug_line.dwo contents:\n";
unsigned stmtOffset = 0;
DataExtractor lineData(getLineDWOSection().Data, isLittleEndian(),
savedAddressByteSize);
DWARFDebugLine::DumpingState state(OS);
while (DWARFDebugLine::parsePrologue(lineData, &stmtOffset, &state.Prologue))
state.finalize();
}
if (DumpType == DIDT_All || DumpType == DIDT_Str) { if (DumpType == DIDT_All || DumpType == DIDT_Str) {
OS << "\n.debug_str contents:\n"; OS << "\n.debug_str contents:\n";
DataExtractor strData(getStringSection(), isLittleEndian(), 0); DataExtractor strData(getStringSection(), isLittleEndian(), 0);
@ -645,6 +655,7 @@ DWARFContextInMemory::DWARFContextInMemory(object::ObjectFile *Obj) :
.Case("debug_gnu_pubtypes", &GnuPubTypesSection) .Case("debug_gnu_pubtypes", &GnuPubTypesSection)
.Case("debug_info.dwo", &InfoDWOSection.Data) .Case("debug_info.dwo", &InfoDWOSection.Data)
.Case("debug_abbrev.dwo", &AbbrevDWOSection) .Case("debug_abbrev.dwo", &AbbrevDWOSection)
.Case("debug_line.dwo", &LineDWOSection.Data)
.Case("debug_str.dwo", &StringDWOSection) .Case("debug_str.dwo", &StringDWOSection)
.Case("debug_str_offsets.dwo", &StringOffsetDWOSection) .Case("debug_str_offsets.dwo", &StringOffsetDWOSection)
.Case("debug_addr", &AddrSection) .Case("debug_addr", &AddrSection)

View File

@ -166,6 +166,7 @@ public:
virtual StringRef getARangeSection() = 0; virtual StringRef getARangeSection() = 0;
virtual StringRef getDebugFrameSection() = 0; virtual StringRef getDebugFrameSection() = 0;
virtual const Section &getLineSection() = 0; virtual const Section &getLineSection() = 0;
virtual const Section &getLineDWOSection() = 0;
virtual StringRef getStringSection() = 0; virtual StringRef getStringSection() = 0;
virtual StringRef getRangeSection() = 0; virtual StringRef getRangeSection() = 0;
virtual StringRef getPubNamesSection() = 0; virtual StringRef getPubNamesSection() = 0;
@ -208,6 +209,7 @@ class DWARFContextInMemory : public DWARFContext {
StringRef ARangeSection; StringRef ARangeSection;
StringRef DebugFrameSection; StringRef DebugFrameSection;
Section LineSection; Section LineSection;
Section LineDWOSection;
StringRef StringSection; StringRef StringSection;
StringRef RangeSection; StringRef RangeSection;
StringRef PubNamesSection; StringRef PubNamesSection;
@ -238,6 +240,7 @@ public:
virtual StringRef getARangeSection() { return ARangeSection; } virtual StringRef getARangeSection() { return ARangeSection; }
virtual StringRef getDebugFrameSection() { return DebugFrameSection; } virtual StringRef getDebugFrameSection() { return DebugFrameSection; }
virtual const Section &getLineSection() { return LineSection; } virtual const Section &getLineSection() { return LineSection; }
virtual const Section &getLineDWOSection() { return LineDWOSection; }
virtual StringRef getStringSection() { return StringSection; } virtual StringRef getStringSection() { return StringSection; }
virtual StringRef getRangeSection() { return RangeSection; } virtual StringRef getRangeSection() { return RangeSection; }
virtual StringRef getPubNamesSection() { return PubNamesSection; } virtual StringRef getPubNamesSection() { return PubNamesSection; }

View File

@ -18,14 +18,15 @@ using namespace dwarf;
void DWARFDebugLine::Prologue::dump(raw_ostream &OS) const { void DWARFDebugLine::Prologue::dump(raw_ostream &OS) const {
OS << "Line table prologue:\n" OS << "Line table prologue:\n"
<< format(" total_length: 0x%8.8x\n", TotalLength) << format(" total_length: 0x%8.8x\n", TotalLength)
<< format(" version: %u\n", Version) << format(" version: %u\n", Version)
<< format("prologue_length: 0x%8.8x\n", PrologueLength) << format(" prologue_length: 0x%8.8x\n", PrologueLength)
<< format("min_inst_length: %u\n", MinInstLength) << format(" min_inst_length: %u\n", MinInstLength)
<< format("default_is_stmt: %u\n", DefaultIsStmt) << format(Version >= 4 ? "max_ops_per_inst: %u\n" : "", MaxOpsPerInst)
<< format(" line_base: %i\n", LineBase) << format(" default_is_stmt: %u\n", DefaultIsStmt)
<< format(" line_range: %u\n", LineRange) << format(" line_base: %i\n", LineBase)
<< format(" opcode_base: %u\n", OpcodeBase); << format(" line_range: %u\n", LineRange)
<< format(" opcode_base: %u\n", OpcodeBase);
for (uint32_t i = 0; i < StandardOpcodeLengths.size(); ++i) for (uint32_t i = 0; i < StandardOpcodeLengths.size(); ++i)
OS << format("standard_opcode_lengths[%s] = %u\n", LNStandardString(i+1), OS << format("standard_opcode_lengths[%s] = %u\n", LNStandardString(i+1),
@ -172,12 +173,14 @@ DWARFDebugLine::parsePrologue(DataExtractor debug_line_data,
prologue->clear(); prologue->clear();
prologue->TotalLength = debug_line_data.getU32(offset_ptr); prologue->TotalLength = debug_line_data.getU32(offset_ptr);
prologue->Version = debug_line_data.getU16(offset_ptr); prologue->Version = debug_line_data.getU16(offset_ptr);
if (prologue->Version != 2) if (prologue->Version < 2)
return false; return false;
prologue->PrologueLength = debug_line_data.getU32(offset_ptr); prologue->PrologueLength = debug_line_data.getU32(offset_ptr);
const uint32_t end_prologue_offset = prologue->PrologueLength + *offset_ptr; const uint32_t end_prologue_offset = prologue->PrologueLength + *offset_ptr;
prologue->MinInstLength = debug_line_data.getU8(offset_ptr); prologue->MinInstLength = debug_line_data.getU8(offset_ptr);
if (prologue->Version >= 4)
prologue->MaxOpsPerInst = debug_line_data.getU8(offset_ptr);
prologue->DefaultIsStmt = debug_line_data.getU8(offset_ptr); prologue->DefaultIsStmt = debug_line_data.getU8(offset_ptr);
prologue->LineBase = debug_line_data.getU8(offset_ptr); prologue->LineBase = debug_line_data.getU8(offset_ptr);
prologue->LineRange = debug_line_data.getU8(offset_ptr); prologue->LineRange = debug_line_data.getU8(offset_ptr);
@ -220,10 +223,9 @@ DWARFDebugLine::parsePrologue(DataExtractor debug_line_data,
return true; return true;
} }
bool bool DWARFDebugLine::parseStatementTable(DataExtractor debug_line_data,
DWARFDebugLine::parseStatementTable(DataExtractor debug_line_data, const RelocAddrMap *RMap,
const RelocAddrMap *RMap, uint32_t *offset_ptr, State &state) {
uint32_t *offset_ptr, State &state) {
const uint32_t debug_line_offset = *offset_ptr; const uint32_t debug_line_offset = *offset_ptr;
Prologue *prologue = &state.Prologue; Prologue *prologue = &state.Prologue;

View File

@ -34,8 +34,9 @@ public:
struct Prologue { struct Prologue {
Prologue() Prologue()
: TotalLength(0), Version(0), PrologueLength(0), MinInstLength(0), : TotalLength(0), Version(0), PrologueLength(0), MinInstLength(0),
DefaultIsStmt(0), LineBase(0), LineRange(0), OpcodeBase(0) {} MaxOpsPerInst(0), DefaultIsStmt(0), LineBase(0), LineRange(0),
OpcodeBase(0) {}
// The size in bytes of the statement information for this compilation unit // The size in bytes of the statement information for this compilation unit
// (not including the total_length field itself). // (not including the total_length field itself).
@ -49,6 +50,9 @@ public:
// program opcodes that alter the address register first multiply their // program opcodes that alter the address register first multiply their
// operands by this value. // operands by this value.
uint8_t MinInstLength; uint8_t MinInstLength;
// The maximum number of individual operations that may be encoded in an
// instruction.
uint8_t MaxOpsPerInst;
// The initial value of theis_stmtregister. // The initial value of theis_stmtregister.
uint8_t DefaultIsStmt; uint8_t DefaultIsStmt;
// This parameter affects the meaning of the special opcodes. See below. // This parameter affects the meaning of the special opcodes. See below.

View File

@ -0,0 +1,10 @@
struct foo {
};
foo f;
// Built with GCC
// $ mkdir -p /tmp/dbginfo
// $ cp dwarfdump-line-dwo.cc /tmp/dbginfo
// $ cd /tmp/dbginfo
// $ g++ -c -fdebug-types-section dwarfdump-line-dwo.cc -o <output>

Binary file not shown.

View File

@ -0,0 +1,6 @@
RUN: llvm-dwarfdump %p/Inputs/dwarfdump-line-dwo.elf-x86-64 | FileCheck %s
CHECK: .debug_line.dwo contents:
CHECK: version: 4
CHECK: max_ops_per_inst: 1
CHECK: file_names[ 1]{{.*}}dwarfdump-line-dwo.cc

View File

@ -65,6 +65,7 @@ DumpType("debug-dump", cl::init(DIDT_All),
clEnumValN(DIDT_Types, "types", ".debug_types"), clEnumValN(DIDT_Types, "types", ".debug_types"),
clEnumValN(DIDT_TypesDwo, "types.dwo", ".debug_types.dwo"), clEnumValN(DIDT_TypesDwo, "types.dwo", ".debug_types.dwo"),
clEnumValN(DIDT_Line, "line", ".debug_line"), clEnumValN(DIDT_Line, "line", ".debug_line"),
clEnumValN(DIDT_LineDwo, "line.dwo", ".debug_line.dwo"),
clEnumValN(DIDT_Loc, "loc", ".debug_loc"), clEnumValN(DIDT_Loc, "loc", ".debug_loc"),
clEnumValN(DIDT_Frames, "frames", ".debug_frame"), clEnumValN(DIDT_Frames, "frames", ".debug_frame"),
clEnumValN(DIDT_Ranges, "ranges", ".debug_ranges"), clEnumValN(DIDT_Ranges, "ranges", ".debug_ranges"),