[llvm] r225271 - Don't loop endlessly for MachO files with 0 ncmds

Filipe Cabecinhas me at filcab.net
Tue Jan 6 09:08:27 PST 2015


Author: filcab
Date: Tue Jan  6 11:08:26 2015
New Revision: 225271

URL: http://llvm.org/viewvc/llvm-project?rev=225271&view=rev
Log:
Don't loop endlessly for MachO files with 0 ncmds

Added:
    llvm/trunk/test/Object/Inputs/macho-zero-ncmds
    llvm/trunk/test/Object/objdump-macho-quirks.test
Modified:
    llvm/trunk/lib/Object/MachOObjectFile.cpp
    llvm/trunk/tools/llvm-objdump/MachODump.cpp

Modified: llvm/trunk/lib/Object/MachOObjectFile.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Object/MachOObjectFile.cpp?rev=225271&r1=225270&r2=225271&view=diff
==============================================================================
--- llvm/trunk/lib/Object/MachOObjectFile.cpp (original)
+++ llvm/trunk/lib/Object/MachOObjectFile.cpp Tue Jan  6 11:08:26 2015
@@ -236,6 +236,9 @@ MachOObjectFile::MachOObjectFile(MemoryB
       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;
 

Added: llvm/trunk/test/Object/Inputs/macho-zero-ncmds
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Object/Inputs/macho-zero-ncmds?rev=225271&view=auto
==============================================================================
Binary files llvm/trunk/test/Object/Inputs/macho-zero-ncmds (added) and llvm/trunk/test/Object/Inputs/macho-zero-ncmds Tue Jan  6 11:08:26 2015 differ

Added: llvm/trunk/test/Object/objdump-macho-quirks.test
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Object/objdump-macho-quirks.test?rev=225271&view=auto
==============================================================================
--- llvm/trunk/test/Object/objdump-macho-quirks.test (added)
+++ llvm/trunk/test/Object/objdump-macho-quirks.test Tue Jan  6 11:08:26 2015
@@ -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
+

Modified: llvm/trunk/tools/llvm-objdump/MachODump.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-objdump/MachODump.cpp?rev=225271&r1=225270&r2=225271&view=diff
==============================================================================
--- llvm/trunk/tools/llvm-objdump/MachODump.cpp (original)
+++ llvm/trunk/tools/llvm-objdump/MachODump.cpp Tue Jan  6 11:08:26 2015
@@ -4204,6 +4204,8 @@ static void PrintLinkEditDataCommand(Mac
 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) {





More information about the llvm-commits mailing list