diff options
| -rw-r--r-- | include/llvm/DebugInfo/DIContext.h | 20 | ||||
| -rw-r--r-- | lib/DebugInfo/DWARFCompileUnit.cpp | 7 | ||||
| -rw-r--r-- | lib/DebugInfo/DWARFCompileUnit.h | 2 | ||||
| -rw-r--r-- | lib/DebugInfo/DWARFContext.cpp | 30 | ||||
| -rw-r--r-- | lib/DebugInfo/DWARFDebugLine.h | 7 | ||||
| -rwxr-xr-x | test/DebugInfo/Inputs/dwarfdump-test.elf-x86-64 | bin | 10246 -> 10174 bytes | |||
| -rwxr-xr-x | test/DebugInfo/Inputs/dwarfdump-test2.elf-x86-64 | bin | 7774 -> 7702 bytes | |||
| -rwxr-xr-x | test/DebugInfo/Inputs/dwarfdump-test3.elf-x86-64 | bin | 6794 -> 7339 bytes | |||
| -rw-r--r-- | test/DebugInfo/dwarfdump-test.test | 24 | ||||
| -rw-r--r-- | tools/llvm-dwarfdump/llvm-dwarfdump.cpp | 3 | 
10 files changed, 69 insertions, 24 deletions
| diff --git a/include/llvm/DebugInfo/DIContext.h b/include/llvm/DebugInfo/DIContext.h index 6377acb..cfdeb46 100644 --- a/include/llvm/DebugInfo/DIContext.h +++ b/include/llvm/DebugInfo/DIContext.h @@ -15,9 +15,9 @@  #ifndef LLVM_DEBUGINFO_DICONTEXT_H  #define LLVM_DEBUGINFO_DICONTEXT_H +#include "llvm/ADT/SmallString.h"  #include "llvm/ADT/StringRef.h"  #include "llvm/Support/DataTypes.h" -#include <cstring>  namespace llvm { @@ -25,28 +25,29 @@ class raw_ostream;  /// DILineInfo - a format-neutral container for source line information.  class DILineInfo { -  const char *FileName; -  const char *FunctionName; +  SmallString<16> FileName; +  SmallString<16> FunctionName;    uint32_t Line;    uint32_t Column;  public:    DILineInfo()      : FileName("<invalid>"), FunctionName("<invalid>"),        Line(0), Column(0) {} -  DILineInfo(const char *fileName, const char *functionName, +  DILineInfo(const SmallString<16> &fileName, +             const SmallString<16> &functionName,               uint32_t line, uint32_t column)      : FileName(fileName), FunctionName(functionName),        Line(line), Column(column) {} -  const char *getFileName() const { return FileName; } -  const char *getFunctionName() const { return FunctionName; } +  const char *getFileName() { return FileName.c_str(); } +  const char *getFunctionName() { return FunctionName.c_str(); }    uint32_t getLine() const { return Line; }    uint32_t getColumn() const { return Column; }    bool operator==(const DILineInfo &RHS) const {      return Line == RHS.Line && Column == RHS.Column && -           std::strcmp(FileName, RHS.FileName) == 0 && -           std::strcmp(FunctionName, RHS.FunctionName) == 0; +           FileName.equals(RHS.FileName) && +           FunctionName.equals(RHS.FunctionName);    }    bool operator!=(const DILineInfo &RHS) const {      return !(*this == RHS); @@ -60,7 +61,8 @@ class DILineInfoSpecifier {  public:    enum Specification {      FileLineInfo = 1 << 0, -    FunctionName = 1 << 1 +    AbsoluteFilePath = 1 << 1, +    FunctionName = 1 << 2    };    // Use file/line info by default.    DILineInfoSpecifier(uint32_t flags = FileLineInfo) : Flags(flags) {} diff --git a/lib/DebugInfo/DWARFCompileUnit.cpp b/lib/DebugInfo/DWARFCompileUnit.cpp index 6d4c7df..b27d57b 100644 --- a/lib/DebugInfo/DWARFCompileUnit.cpp +++ b/lib/DebugInfo/DWARFCompileUnit.cpp @@ -97,6 +97,13 @@ void DWARFCompileUnit::dump(raw_ostream &OS) {    getCompileUnitDIE(false)->dump(OS, this, -1U);  } +const char *DWARFCompileUnit::getCompilationDir() { +  extractDIEsIfNeeded(true); +  if (DieArray.empty()) +    return 0; +  return DieArray[0].getAttributeValueAsString(this, DW_AT_comp_dir, 0); +} +  void DWARFCompileUnit::setDIERelations() {    if (DieArray.empty())      return; diff --git a/lib/DebugInfo/DWARFCompileUnit.h b/lib/DebugInfo/DWARFCompileUnit.h index e8a97ec..b34a596 100644 --- a/lib/DebugInfo/DWARFCompileUnit.h +++ b/lib/DebugInfo/DWARFCompileUnit.h @@ -78,6 +78,8 @@ public:      return &DieArray[0];    } +  const char *getCompilationDir(); +    /// 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 08e5db2..a4e0d8e 100644 --- a/lib/DebugInfo/DWARFContext.cpp +++ b/lib/DebugInfo/DWARFContext.cpp @@ -8,8 +8,10 @@  //===----------------------------------------------------------------------===//  #include "DWARFContext.h" +#include "llvm/ADT/SmallString.h"  #include "llvm/Support/Dwarf.h"  #include "llvm/Support/Format.h" +#include "llvm/Support/Path.h"  #include "llvm/Support/raw_ostream.h"  #include <algorithm>  using namespace llvm; @@ -148,8 +150,8 @@ DILineInfo DWARFContext::getLineInfoForAddress(uint64_t address,    DWARFCompileUnit *cu = getCompileUnitForOffset(cuOffset);    if (!cu)      return DILineInfo(); -  const char *fileName = "<invalid>"; -  const char *functionName = "<invalid>"; +  SmallString<16> fileName("<invalid>"); +  SmallString<16> functionName("<invalid>");    uint32_t line = 0;    uint32_t column = 0;    if (specifier.needs(DILineInfoSpecifier::FunctionName)) { @@ -171,7 +173,29 @@ DILineInfo DWARFContext::getLineInfoForAddress(uint64_t address,        if (rowIndex != -1U) {          const DWARFDebugLine::Row &row = lineTable->Rows[rowIndex];          // Take file/line info from the line table. -        fileName = lineTable->Prologue.FileNames[row.File - 1].Name.c_str(); +        const DWARFDebugLine::FileNameEntry &fileNameEntry = +            lineTable->Prologue.FileNames[row.File - 1]; +        fileName = fileNameEntry.Name; +        if (specifier.needs(DILineInfoSpecifier::AbsoluteFilePath) && +            sys::path::is_relative(fileName.str())) { +          // Append include directory of file (if it is present in line table) +          // and compilation directory of compile unit to make path absolute. +          const char *includeDir = 0; +          if (uint64_t includeDirIndex = fileNameEntry.DirIdx) { +            includeDir = lineTable->Prologue +                         .IncludeDirectories[includeDirIndex - 1]; +          } +          SmallString<16> absFileName; +          if (includeDir == 0 || sys::path::is_relative(includeDir)) { +            if (const char *compilationDir = cu->getCompilationDir()) +              sys::path::append(absFileName, compilationDir); +          } +          if (includeDir) { +            sys::path::append(absFileName, includeDir); +          } +          sys::path::append(absFileName, fileName.str()); +          fileName = absFileName; +        }          line = row.Line;          column = row.Column;        } diff --git a/lib/DebugInfo/DWARFDebugLine.h b/lib/DebugInfo/DWARFDebugLine.h index bc6a70b..a8c0669 100644 --- a/lib/DebugInfo/DWARFDebugLine.h +++ b/lib/DebugInfo/DWARFDebugLine.h @@ -12,7 +12,6 @@  #include "llvm/Support/DataExtractor.h"  #include <map> -#include <string>  #include <vector>  namespace llvm { @@ -22,9 +21,9 @@ class raw_ostream;  class DWARFDebugLine {  public:    struct FileNameEntry { -    FileNameEntry() : DirIdx(0), ModTime(0), Length(0) {} +    FileNameEntry() : Name(0), DirIdx(0), ModTime(0), Length(0) {} -    std::string Name; +    const char *Name;      uint64_t DirIdx;      uint64_t ModTime;      uint64_t Length; @@ -56,7 +55,7 @@ public:      // The number assigned to the first special opcode.      uint8_t OpcodeBase;      std::vector<uint8_t> StandardOpcodeLengths; -    std::vector<std::string> IncludeDirectories; +    std::vector<const char*> IncludeDirectories;      std::vector<FileNameEntry> FileNames;      // Length of the prologue in bytes. diff --git a/test/DebugInfo/Inputs/dwarfdump-test.elf-x86-64 b/test/DebugInfo/Inputs/dwarfdump-test.elf-x86-64Binary files differ index 7cee968..fe20c8e 100755 --- a/test/DebugInfo/Inputs/dwarfdump-test.elf-x86-64 +++ b/test/DebugInfo/Inputs/dwarfdump-test.elf-x86-64 diff --git a/test/DebugInfo/Inputs/dwarfdump-test2.elf-x86-64 b/test/DebugInfo/Inputs/dwarfdump-test2.elf-x86-64Binary files differ index a226e79..ce4af7f 100755 --- a/test/DebugInfo/Inputs/dwarfdump-test2.elf-x86-64 +++ b/test/DebugInfo/Inputs/dwarfdump-test2.elf-x86-64 diff --git a/test/DebugInfo/Inputs/dwarfdump-test3.elf-x86-64 b/test/DebugInfo/Inputs/dwarfdump-test3.elf-x86-64Binary files differ index fb3ca03..7c17304 100755 --- a/test/DebugInfo/Inputs/dwarfdump-test3.elf-x86-64 +++ b/test/DebugInfo/Inputs/dwarfdump-test3.elf-x86-64 diff --git a/test/DebugInfo/dwarfdump-test.test b/test/DebugInfo/dwarfdump-test.test index 7b01e38..beac51f 100644 --- a/test/DebugInfo/dwarfdump-test.test +++ b/test/DebugInfo/dwarfdump-test.test @@ -9,22 +9,32 @@ RUN:   --address=0x4004b8 --functions | FileCheck %s -check-prefix MANY_CU_1  RUN: llvm-dwarfdump %p/Inputs/dwarfdump-test2.elf-x86-64 \  RUN:   --address=0x4004c4 --functions | FileCheck %s -check-prefix MANY_CU_2  RUN: llvm-dwarfdump %p/Inputs/dwarfdump-test3.elf-x86-64 \ -RUN:   --address=0x538 --functions | FileCheck %s -check-prefix ABS_ORIGIN_1 +RUN:   --address=0x580 --functions | FileCheck %s -check-prefix ABS_ORIGIN_1 +RUN: llvm-dwarfdump %p/Inputs/dwarfdump-test3.elf-x86-64 \ +RUN:   --address=0x573 --functions | FileCheck %s -check-prefix INCLUDE_TEST_1 +RUN: llvm-dwarfdump %p/Inputs/dwarfdump-test3.elf-x86-64 \ +RUN:   --address=0x56d --functions | FileCheck %s -check-prefix INCLUDE_TEST_2  MAIN: main -MAIN-NEXT: dwarfdump-test.cc:16:10 +MAIN-NEXT: /tmp/dbginfo/dwarfdump-test.cc:16:10  FUNCTION: _Z1fii -FUNCTION-NEXT: dwarfdump-test.cc:11:18 +FUNCTION-NEXT: /tmp/dbginfo/dwarfdump-test.cc:11:18  CTOR_WITH_SPEC: _ZN10DummyClassC1Ei -CTOR_WITH_SPEC-NEXT: dwarfdump-test.cc:4:30 +CTOR_WITH_SPEC-NEXT: /tmp/dbginfo/dwarfdump-test.cc:4:30  MANY_CU_1: a -MANY_CU_1-NEXT: a.cc:2:0 +MANY_CU_1-NEXT: /tmp/dbginfo/a.cc:2:0  MANY_CU_2: main -MANY_CU_2-NEXT: main.cc:4:0 +MANY_CU_2-NEXT: /tmp/dbginfo/main.cc:4:0  ABS_ORIGIN_1: C -ABS_ORIGIN_1-NEXT: def.cc:3:0 +ABS_ORIGIN_1-NEXT: /tmp/dbginfo/def2.cc:4:0 + +INCLUDE_TEST_1: _Z3do2v +INCLUDE_TEST_1-NEXT: /tmp/dbginfo/include/decl2.h:1:0 + +INCLUDE_TEST_2: _Z3do1v +INCLUDE_TEST_2-NEXT: /tmp/include/decl.h:5:0 diff --git a/tools/llvm-dwarfdump/llvm-dwarfdump.cpp b/tools/llvm-dwarfdump/llvm-dwarfdump.cpp index b6536fa..ec0b4ae 100644 --- a/tools/llvm-dwarfdump/llvm-dwarfdump.cpp +++ b/tools/llvm-dwarfdump/llvm-dwarfdump.cpp @@ -97,7 +97,8 @@ static void DumpInput(const StringRef &Filename) {      dictx->dump(outs());    } else {      // Print line info for the specified address. -    int spec_flags = DILineInfoSpecifier::FileLineInfo; +    int spec_flags = DILineInfoSpecifier::FileLineInfo | +                     DILineInfoSpecifier::AbsoluteFilePath;      if (PrintFunctions)        spec_flags |= DILineInfoSpecifier::FunctionName;      DILineInfo dli = dictx->getLineInfoForAddress(Address, spec_flags); | 
