summaryrefslogtreecommitdiffstats
path: root/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp
diff options
context:
space:
mode:
authorFrederic Riss <friss@apple.com>2015-08-03 00:10:31 +0000
committerFrederic Riss <friss@apple.com>2015-08-03 00:10:31 +0000
commit4c5d357b57ea9717edb3f8efecdef6d4fbc13042 (patch)
tree86d3397d2820563bbe20c1ca7af0c343a5be9de0 /llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp
parent40c01793f48fa1ca652f54a1f1f88c400b319eda (diff)
downloadbcm5719-llvm-4c5d357b57ea9717edb3f8efecdef6d4fbc13042.tar.gz
bcm5719-llvm-4c5d357b57ea9717edb3f8efecdef6d4fbc13042.zip
[dwarfdump] Add support for dumping mach-o universal objectfiles
llvm-svn: 243862
Diffstat (limited to 'llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp')
-rw-r--r--llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp24
1 files changed, 16 insertions, 8 deletions
diff --git a/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp b/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp
index 018e6662fac..f641c6be536 100644
--- a/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp
+++ b/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp
@@ -15,6 +15,7 @@
#include "llvm/ADT/Triple.h"
#include "llvm/DebugInfo/DIContext.h"
#include "llvm/DebugInfo/DWARF/DWARFContext.h"
+#include "llvm/Object/MachOUniversal.h"
#include "llvm/Object/ObjectFile.h"
#include "llvm/Object/RelocVisitor.h"
#include "llvm/Support/CommandLine.h"
@@ -76,11 +77,11 @@ static void error(StringRef Filename, std::error_code EC) {
exit(1);
}
-static void DumpObjectFile(ObjectFile &Obj, StringRef Filename) {
+static void DumpObjectFile(ObjectFile &Obj, Twine Filename) {
std::unique_ptr<DIContext> DICtx(new DWARFContextInMemory(Obj));
- outs() << Filename
- << ":\tfile format " << Obj.getFileFormatName() << "\n\n";
+ outs() << Filename.str() << ":\tfile format " << Obj.getFileFormatName()
+ << "\n\n";
// Dump the complete DWARF structure.
DICtx->dump(outs(), DumpType);
}
@@ -91,12 +92,19 @@ static void DumpInput(StringRef Filename) {
error(Filename, BuffOrErr.getError());
std::unique_ptr<MemoryBuffer> Buff = std::move(BuffOrErr.get());
- ErrorOr<std::unique_ptr<ObjectFile>> ObjOrErr =
- ObjectFile::createObjectFile(Buff->getMemBufferRef());
- error(Filename, ObjOrErr.getError());
- ObjectFile &Obj = *ObjOrErr.get();
+ ErrorOr<std::unique_ptr<Binary>> BinOrErr =
+ object::createBinary(Buff->getMemBufferRef());
+ error(Filename, BinOrErr.getError());
- DumpObjectFile(Obj, Filename);
+ if (auto *Obj = dyn_cast<ObjectFile>(BinOrErr->get()))
+ DumpObjectFile(*Obj, Filename);
+ else if (auto *Fat = dyn_cast<MachOUniversalBinary>(BinOrErr->get()))
+ for (auto &ObjForArch : Fat->objects()) {
+ auto MachOOrErr = ObjForArch.getAsObjectFile();
+ error(Filename, MachOOrErr.getError());
+ DumpObjectFile(**MachOOrErr,
+ Filename + " (" + ObjForArch.getArchTypeName() + ")");
+ }
}
int main(int argc, char **argv) {
OpenPOWER on IntegriCloud