diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2011-09-15 18:02:20 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2011-09-15 18:02:20 +0000 |
commit | fe80f1da404d25f93e4a2492b127554a882bd5bb (patch) | |
tree | a4c54f057d1619c6cf825248f6b9c9d6ae70aa3e /lib/DebugInfo | |
parent | 10ec65004d8da411ab59a1fee85c0ff54539776a (diff) |
DWARF: Print line tables per compile unit, so they get the right address size.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@139808 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/DebugInfo')
-rw-r--r-- | lib/DebugInfo/DWARFCompileUnit.cpp | 3 | ||||
-rw-r--r-- | lib/DebugInfo/DWARFCompileUnit.h | 8 | ||||
-rw-r--r-- | lib/DebugInfo/DWARFContext.cpp | 17 |
3 files changed, 23 insertions, 5 deletions
diff --git a/lib/DebugInfo/DWARFCompileUnit.cpp b/lib/DebugInfo/DWARFCompileUnit.cpp index d535df05d3..24bf97ff60 100644 --- a/lib/DebugInfo/DWARFCompileUnit.cpp +++ b/lib/DebugInfo/DWARFCompileUnit.cpp @@ -94,8 +94,7 @@ void DWARFCompileUnit::dump(raw_ostream &OS) { << " (next CU at " << format("0x%08x", getNextCompileUnitOffset()) << ")\n"; - extractDIEsIfNeeded(false); - DieArray[0].dump(OS, this, -1U); + getCompileUnitDIE(false)->dump(OS, this, -1U); } void DWARFCompileUnit::setDIERelations() { diff --git a/lib/DebugInfo/DWARFCompileUnit.h b/lib/DebugInfo/DWARFCompileUnit.h index 378b6ced8c..d9167292a9 100644 --- a/lib/DebugInfo/DWARFCompileUnit.h +++ b/lib/DebugInfo/DWARFCompileUnit.h @@ -70,6 +70,14 @@ public: BaseAddr = base_addr; } + const DWARFDebugInfoEntryMinimal * + getCompileUnitDIE(bool extract_cu_die_only = true) { + extractDIEsIfNeeded(extract_cu_die_only); + if (DieArray.empty()) + return NULL; + return &DieArray[0]; + } + /// setDIERelations - We read in all of the DIE entries into our flat list /// of DIE entries and now we need to go back through all of them and set the /// parent, sibling and child pointers for quick DIE navigation. diff --git a/lib/DebugInfo/DWARFContext.cpp b/lib/DebugInfo/DWARFContext.cpp index 215effac41..184a8b595c 100644 --- a/lib/DebugInfo/DWARFContext.cpp +++ b/lib/DebugInfo/DWARFContext.cpp @@ -8,9 +8,11 @@ //===----------------------------------------------------------------------===// #include "DWARFContext.h" +#include "llvm/Support/Dwarf.h" #include "llvm/Support/Format.h" #include "llvm/Support/raw_ostream.h" using namespace llvm; +using namespace dwarf; void DWARFContext::dump(raw_ostream &OS) { OS << ".debug_abbrev contents:\n"; @@ -28,9 +30,18 @@ void DWARFContext::dump(raw_ostream &OS) { set.dump(OS); OS << "\n.debug_lines contents:\n"; - // FIXME: must be done per CU. - DataExtractor lineData(getLineSection(), isLittleEndian(), /*FIXME*/8); - DWARFDebugLine::dump(lineData, OS); + for (unsigned i = 0, e = getNumCompileUnits(); i != e; ++i) { + DWARFCompileUnit *cu = getCompileUnitAtIndex(i); + unsigned stmtOffset = + cu->getCompileUnitDIE()->getAttributeValueAsUnsigned(cu, DW_AT_stmt_list, + -1U); + if (stmtOffset != -1U) { + DataExtractor lineData(getLineSection(), isLittleEndian(), + cu->getAddressByteSize()); + DWARFDebugLine::DumpingState state(OS); + DWARFDebugLine::parseStatementTable(lineData, &stmtOffset, state); + } + } OS << "\n.debug_str contents:\n"; DataExtractor strData(getStringSection(), isLittleEndian(), 0); |