diff options
author | Martin Storsjo <martin@martin.st> | 2017-07-13 17:03:02 +0000 |
---|---|---|
committer | Martin Storsjo <martin@martin.st> | 2017-07-13 17:03:02 +0000 |
commit | 8c0317da023510a221ec8291083cf3dd2ce3b1b5 (patch) | |
tree | 3d8c0f003eb4b24142a636540ac2623e2768f5de /llvm/tools/llvm-objdump/llvm-objdump.cpp | |
parent | 64321a190e12c04fac65743ff951322560d8dbb0 (diff) | |
download | bcm5719-llvm-8c0317da023510a221ec8291083cf3dd2ce3b1b5.tar.gz bcm5719-llvm-8c0317da023510a221ec8291083cf3dd2ce3b1b5.zip |
[llvm-objdump] Properly print MachO aarch64 addend relocations
Previously such relocations fell into the last case for local
symbols, using the relocation addend as symbol index, leading to
a crash.
Differential Revision: https://reviews.llvm.org/D35239
llvm-svn: 307927
Diffstat (limited to 'llvm/tools/llvm-objdump/llvm-objdump.cpp')
-rw-r--r-- | llvm/tools/llvm-objdump/llvm-objdump.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/llvm/tools/llvm-objdump/llvm-objdump.cpp b/llvm/tools/llvm-objdump/llvm-objdump.cpp index 812f1af3ac6..d54b45515f0 100644 --- a/llvm/tools/llvm-objdump/llvm-objdump.cpp +++ b/llvm/tools/llvm-objdump/llvm-objdump.cpp @@ -870,7 +870,10 @@ static void printRelocationTargetName(const MachOObjectFile *O, bool isExtern = O->getPlainRelocationExternal(RE); uint64_t Val = O->getPlainRelocationSymbolNum(RE); - if (isExtern) { + if (O->getAnyRelocationType(RE) == MachO::ARM64_RELOC_ADDEND) { + fmt << format("0x%x", Val); + return; + } else if (isExtern) { symbol_iterator SI = O->symbol_begin(); advance(SI, Val); Expected<StringRef> SOrErr = SI->getName(); |