summaryrefslogtreecommitdiffstats
path: root/llvm/tools/llvm-objdump
diff options
context:
space:
mode:
authorRui Ueyama <ruiu@google.com>2014-02-28 05:21:29 +0000
committerRui Ueyama <ruiu@google.com>2014-02-28 05:21:29 +0000
commitcf39784b3a82690b17f1ce6cba62f704e92e7016 (patch)
tree15be7dc01d8cb96c0b9857acf90242b04695405b /llvm/tools/llvm-objdump
parent1618fe25d163cfa700f8c03f3effce74666df7a5 (diff)
downloadbcm5719-llvm-cf39784b3a82690b17f1ce6cba62f704e92e7016.tar.gz
bcm5719-llvm-cf39784b3a82690b17f1ce6cba62f704e92e7016.zip
llvm-objdump: Fix crash bug with printing unwind info on stripped file.
The current COFF unwind printer tries to print SEH handler function names, assuming that it can always find function names in string table. It crashes if file being read has no symbol table (i.e. executable). With this patch, llvm-objdump prints SEH handler's RVA if there's no symbol table entry for that RVA. llvm-svn: 202466
Diffstat (limited to 'llvm/tools/llvm-objdump')
-rw-r--r--llvm/tools/llvm-objdump/COFFDump.cpp16
1 files changed, 9 insertions, 7 deletions
diff --git a/llvm/tools/llvm-objdump/COFFDump.cpp b/llvm/tools/llvm-objdump/COFFDump.cpp
index c4bd81adedc..0b7f64d39e6 100644
--- a/llvm/tools/llvm-objdump/COFFDump.cpp
+++ b/llvm/tools/llvm-objdump/COFFDump.cpp
@@ -182,10 +182,10 @@ static error_code resolveSymbol(const std::vector<RelocationRef> &Rels,
return EC;
if (Ofs == Offset) {
Sym = *I->getSymbol();
- break;
+ return object_error::success;
}
}
- return object_error::success;
+ return object_error::parse_failed;
}
// Given a vector of relocations for a section and an offset into this section
@@ -225,11 +225,13 @@ static void printCOFFSymbolAddress(llvm::raw_ostream &Out,
const std::vector<RelocationRef> &Rels,
uint64_t Offset, uint32_t Disp) {
StringRef Sym;
- if (error(resolveSymbolName(Rels, Offset, Sym)))
- return;
- Out << Sym;
- if (Disp > 0)
- Out << format(" + 0x%04x", Disp);
+ if (!resolveSymbolName(Rels, Offset, Sym)) {
+ Out << Sym;
+ if (Disp > 0)
+ Out << format(" + 0x%04x", Disp);
+ } else {
+ Out << format("0x%04x", Disp);
+ }
}
static void
OpenPOWER on IntegriCloud