diff options
author | Reid Kleckner <rnk@google.com> | 2015-10-09 00:15:01 +0000 |
---|---|---|
committer | Reid Kleckner <rnk@google.com> | 2015-10-09 00:15:01 +0000 |
commit | e94fef7b3d2efbdbd22098e4ead372033bf731ab (patch) | |
tree | 61d9953f625179af720486c1f6508f0616d3d1fc /llvm/lib/Object/COFFObjectFile.cpp | |
parent | d837cd044fd21ba182d4af49d3885dcd59a5d6a4 (diff) | |
download | bcm5719-llvm-e94fef7b3d2efbdbd22098e4ead372033bf731ab.tar.gz bcm5719-llvm-e94fef7b3d2efbdbd22098e4ead372033bf731ab.zip |
[llvm-symbolizer] Make --relative-address work with DWARF contexts
Summary:
Previously the relative address flag only affected PDB debug info. Now
both DIContext implementations always expect to be passed virtual
addresses. llvm-symbolizer is now responsible for adding ImageBase to
module offsets when --relative-offset is passed.
Reviewers: zturner
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D12883
llvm-svn: 249784
Diffstat (limited to 'llvm/lib/Object/COFFObjectFile.cpp')
-rw-r--r-- | llvm/lib/Object/COFFObjectFile.cpp | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/llvm/lib/Object/COFFObjectFile.cpp b/llvm/lib/Object/COFFObjectFile.cpp index d3f604a8d35..efb3ea04083 100644 --- a/llvm/lib/Object/COFFObjectFile.cpp +++ b/llvm/lib/Object/COFFObjectFile.cpp @@ -174,10 +174,7 @@ ErrorOr<uint64_t> COFFObjectFile::getSymbolAddress(DataRefImpl Ref) const { // The section VirtualAddress does not include ImageBase, and we want to // return virtual addresses. - if (PE32Header) - Result += PE32Header->ImageBase; - else if (PE32PlusHeader) - Result += PE32PlusHeader->ImageBase; + Result += getImageBase().get(); return Result; } @@ -274,10 +271,7 @@ uint64_t COFFObjectFile::getSectionAddress(DataRefImpl Ref) const { // The section VirtualAddress does not include ImageBase, and we want to // return virtual addresses. - if (PE32Header) - Result += PE32Header->ImageBase; - else if (PE32PlusHeader) - Result += PE32PlusHeader->ImageBase; + Result += getImageBase().get(); return Result; } @@ -424,10 +418,17 @@ std::error_code COFFObjectFile::initSymbolTablePtr() { return std::error_code(); } +ErrorOr<uint64_t> COFFObjectFile::getImageBase() const { + if (PE32Header) + return uint64_t(PE32Header->ImageBase); + else if (PE32PlusHeader) + return uint64_t(PE32PlusHeader->ImageBase); + return object_error::parse_failed; +} + // Returns the file offset for the given VA. std::error_code COFFObjectFile::getVaPtr(uint64_t Addr, uintptr_t &Res) const { - uint64_t ImageBase = PE32Header ? (uint64_t)PE32Header->ImageBase - : (uint64_t)PE32PlusHeader->ImageBase; + uint64_t ImageBase = getImageBase().get(); uint64_t Rva = Addr - ImageBase; assert(Rva <= UINT32_MAX); return getRvaPtr((uint32_t)Rva, Res); |