summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexey Samsonov <vonosmas@gmail.com>2015-06-04 22:58:25 +0000
committerAlexey Samsonov <vonosmas@gmail.com>2015-06-04 22:58:25 +0000
commit18ad2e54ab8012e3dd8bffc6f0e1a98683afa2fc (patch)
tree971f0ad48dbcc4e2ab4cdfe827684384e0cb2e3f
parent64c2f5a50fa21c04b8a392f9ebed4521ab8413d7 (diff)
downloadbcm5719-llvm-18ad2e54ab8012e3dd8bffc6f0e1a98683afa2fc.tar.gz
bcm5719-llvm-18ad2e54ab8012e3dd8bffc6f0e1a98683afa2fc.zip
[Object, ELF] Don't call llvm_unreachable() from createELFObjectFile.
Instead, return a proper error code from factory. llvm-svn: 239113
-rw-r--r--llvm/lib/Object/ELFObjectFile.cpp4
-rw-r--r--llvm/test/DebugInfo/Inputs/invalid.elf.21
-rw-r--r--llvm/test/DebugInfo/dwarfdump-invalid.test1
3 files changed, 4 insertions, 2 deletions
diff --git a/llvm/lib/Object/ELFObjectFile.cpp b/llvm/lib/Object/ELFObjectFile.cpp
index 8847a20d96e..1ffdc01bcd3 100644
--- a/llvm/lib/Object/ELFObjectFile.cpp
+++ b/llvm/lib/Object/ELFObjectFile.cpp
@@ -38,7 +38,7 @@ ObjectFile::createELFObjectFile(MemoryBufferRef Obj) {
else if (Ident.second == ELF::ELFDATA2MSB)
R.reset(new ELFObjectFile<ELFType<support::big, false>>(Obj, EC));
else
- llvm_unreachable("Buffer is not an ELF object file!");
+ return object_error::parse_failed;
} else {
assert(Ident.first == ELF::ELFCLASS64);
if (Ident.second == ELF::ELFDATA2LSB)
@@ -46,7 +46,7 @@ ObjectFile::createELFObjectFile(MemoryBufferRef Obj) {
else if (Ident.second == ELF::ELFDATA2MSB)
R.reset(new ELFObjectFile<ELFType<support::big, true>>(Obj, EC));
else
- llvm_unreachable("Buffer is not an ELF object file!");
+ return object_error::parse_failed;
}
if (EC)
diff --git a/llvm/test/DebugInfo/Inputs/invalid.elf.2 b/llvm/test/DebugInfo/Inputs/invalid.elf.2
new file mode 100644
index 00000000000..16528a55a93
--- /dev/null
+++ b/llvm/test/DebugInfo/Inputs/invalid.elf.2
@@ -0,0 +1 @@
+ELF'L:þB“ELFï \ No newline at end of file
diff --git a/llvm/test/DebugInfo/dwarfdump-invalid.test b/llvm/test/DebugInfo/dwarfdump-invalid.test
index dcbdd739190..5b616bd5581 100644
--- a/llvm/test/DebugInfo/dwarfdump-invalid.test
+++ b/llvm/test/DebugInfo/dwarfdump-invalid.test
@@ -1,4 +1,5 @@
; Verify that llvm-dwarfdump doesn't crash on broken input files.
RUN: llvm-dwarfdump %p/Inputs/invalid.elf 2>&1 | FileCheck %s --check-prefix=INVALID-ELF
+RUN: llvm-dwarfdump %p/Inputs/invalid.elf.2 2>&1 | FileCheck %s --check-prefix=INVALID-ELF
INVALID-ELF: Invalid data was encountered while parsing the file
OpenPOWER on IntegriCloud