When encountering an unknown file format, ObjectFile::createObjectFile should
authorEli Bendersky <eliben@google.com>
Fri, 25 Jan 2013 20:53:41 +0000 (20:53 +0000)
committerEli Bendersky <eliben@google.com>
Fri, 25 Jan 2013 20:53:41 +0000 (20:53 +0000)
politely report it instead of running into llvm_unreachable.

Also patch llvm-dwarfdump to actually check whether the file it's attempting to
dump is a valid object file.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@173489 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Object/ObjectFile.cpp
tools/llvm-dwarfdump/llvm-dwarfdump.cpp

index b14df9af64f40f5f9ded7f279eb66688a06f8fd8..860c87be9846e8edc220d2848639e76a60ab0768 100644 (file)
@@ -33,6 +33,8 @@ ObjectFile *ObjectFile::createObjectFile(MemoryBuffer *Object) {
   sys::LLVMFileType type = sys::IdentifyFileType(Object->getBufferStart(),
                                 static_cast<unsigned>(Object->getBufferSize()));
   switch (type) {
+    case sys::Unknown_FileType:
+      return 0;
     case sys::ELF_Relocatable_FileType:
     case sys::ELF_Executable_FileType:
     case sys::ELF_SharedObject_FileType:
@@ -52,7 +54,7 @@ ObjectFile *ObjectFile::createObjectFile(MemoryBuffer *Object) {
     case sys::COFF_FileType:
       return createCOFFObjectFile(Object);
     default:
-      llvm_unreachable("Unknown Object File Type");
+      llvm_unreachable("Unexpected Object File Type");
   }
 }
 
index 068750058377266ba5417f64ba68bfa4dfbc7ed1..6041510e039d9f529bfcacad960c8860e8d6c033 100644 (file)
@@ -86,6 +86,11 @@ static void DumpInput(const StringRef &Filename) {
   }
 
   OwningPtr<ObjectFile> Obj(ObjectFile::createObjectFile(Buff.take()));
+  if (!Obj) {
+    errs() << Filename << ": Unknown object file format\n";
+    return;
+  }
+
   OwningPtr<DIContext> DICtx(DIContext::getDWARFContext(Obj.get()));
 
   if (Address == -1ULL) {