summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFilipe Cabecinhas <me@filcab.net>2015-01-06 17:08:26 +0000
committerFilipe Cabecinhas <me@filcab.net>2015-01-06 17:08:26 +0000
commite71bd0c89bfe64fefb703c16397ad0e5debc7802 (patch)
tree61e99b6849eb58765286b6eb6c223e8a946bda1c
parent243a5481d9221bf8733fef538a600bcc6117933e (diff)
downloadbcm5719-llvm-e71bd0c89bfe64fefb703c16397ad0e5debc7802.tar.gz
bcm5719-llvm-e71bd0c89bfe64fefb703c16397ad0e5debc7802.zip
Don't loop endlessly for MachO files with 0 ncmds
llvm-svn: 225271
-rw-r--r--llvm/lib/Object/MachOObjectFile.cpp3
-rw-r--r--llvm/test/Object/Inputs/macho-zero-ncmdsbin0 -> 32 bytes
-rw-r--r--llvm/test/Object/objdump-macho-quirks.test9
-rw-r--r--llvm/tools/llvm-objdump/MachODump.cpp2
4 files changed, 14 insertions, 0 deletions
diff --git a/llvm/lib/Object/MachOObjectFile.cpp b/llvm/lib/Object/MachOObjectFile.cpp
index 1373dbab410..e4769762be4 100644
--- a/llvm/lib/Object/MachOObjectFile.cpp
+++ b/llvm/lib/Object/MachOObjectFile.cpp
@@ -236,6 +236,9 @@ MachOObjectFile::MachOObjectFile(MemoryBufferRef Object, bool IsLittleEndian,
DataInCodeLoadCmd(nullptr), DyldInfoLoadCmd(nullptr),
UuidLoadCmd(nullptr), HasPageZeroSegment(false) {
uint32_t LoadCommandCount = this->getHeader().ncmds;
+ if (LoadCommandCount == 0)
+ return;
+
MachO::LoadCommandType SegmentLoadType = is64Bit() ?
MachO::LC_SEGMENT_64 : MachO::LC_SEGMENT;
diff --git a/llvm/test/Object/Inputs/macho-zero-ncmds b/llvm/test/Object/Inputs/macho-zero-ncmds
new file mode 100644
index 00000000000..0505419195e
--- /dev/null
+++ b/llvm/test/Object/Inputs/macho-zero-ncmds
Binary files differ
diff --git a/llvm/test/Object/objdump-macho-quirks.test b/llvm/test/Object/objdump-macho-quirks.test
new file mode 100644
index 00000000000..eeee1537def
--- /dev/null
+++ b/llvm/test/Object/objdump-macho-quirks.test
@@ -0,0 +1,9 @@
+RUN: llvm-objdump -private-headers %p/Inputs/macho-zero-ncmds \
+RUN: | FileCheck %s -check-prefix A
+
+// Check that we don't get an infinite loop if ncmds = 0
+A: file format Mach-O 64-bit unknown
+A: Mach header
+A: magic cputype cpusubtype caps filetype ncmds sizeofcmds flags
+A: MH_MAGIC_64 0x00 OBJECT 0 0 0x00000000
+
diff --git a/llvm/tools/llvm-objdump/MachODump.cpp b/llvm/tools/llvm-objdump/MachODump.cpp
index 36db9ad5366..935696be04c 100644
--- a/llvm/tools/llvm-objdump/MachODump.cpp
+++ b/llvm/tools/llvm-objdump/MachODump.cpp
@@ -4204,6 +4204,8 @@ static void PrintLinkEditDataCommand(MachO::linkedit_data_command ld,
static void PrintLoadCommands(const MachOObjectFile *Obj, uint32_t ncmds,
uint32_t filetype, uint32_t cputype,
bool verbose) {
+ if (ncmds == 0)
+ return;
StringRef Buf = Obj->getData();
MachOObjectFile::LoadCommandInfo Command = Obj->getFirstLoadCommandInfo();
for (unsigned i = 0;; ++i) {
OpenPOWER on IntegriCloud