[llvm] r224563 - [Object] Don't crash on empty export lists.

Juergen Ributzka juergen at apple.com
Thu Dec 18 18:31:01 PST 2014


Author: ributzka
Date: Thu Dec 18 20:31:01 2014
New Revision: 224563

URL: http://llvm.org/viewvc/llvm-project?rev=224563&view=rev
Log:
[Object] Don't crash on empty export lists.

Summary: This fixes the exports iterator if the export list is empty.

Reviewers: Bigcheese, kledzik

Subscribers: llvm-commits

Differential Revision: http://reviews.llvm.org/D6732

Added:
    llvm/trunk/test/Object/Inputs/macho-no-exports.dylib   (with props)
    llvm/trunk/test/Object/objdump-export-list.test
Modified:
    llvm/trunk/lib/Object/MachOObjectFile.cpp

Modified: llvm/trunk/lib/Object/MachOObjectFile.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Object/MachOObjectFile.cpp?rev=224563&r1=224562&r2=224563&view=diff
==============================================================================
--- llvm/trunk/lib/Object/MachOObjectFile.cpp (original)
+++ llvm/trunk/lib/Object/MachOObjectFile.cpp Thu Dec 18 20:31:01 2014
@@ -1640,7 +1640,10 @@ void ExportEntry::moveNext() {
 iterator_range<export_iterator> 
 MachOObjectFile::exports(ArrayRef<uint8_t> Trie) {
   ExportEntry Start(Trie);
-  Start.moveToFirst();
+  if (Trie.size() == 0)
+    Start.moveToEnd();
+  else
+    Start.moveToFirst();
 
   ExportEntry Finish(Trie);
   Finish.moveToEnd();

Added: llvm/trunk/test/Object/Inputs/macho-no-exports.dylib
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Object/Inputs/macho-no-exports.dylib?rev=224563&view=auto
==============================================================================
Binary files llvm/trunk/test/Object/Inputs/macho-no-exports.dylib (added) and llvm/trunk/test/Object/Inputs/macho-no-exports.dylib Thu Dec 18 20:31:01 2014 differ

Propchange: llvm/trunk/test/Object/Inputs/macho-no-exports.dylib
------------------------------------------------------------------------------
    svn:executable = *

Added: llvm/trunk/test/Object/objdump-export-list.test
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Object/objdump-export-list.test?rev=224563&view=auto
==============================================================================
--- llvm/trunk/test/Object/objdump-export-list.test (added)
+++ llvm/trunk/test/Object/objdump-export-list.test Thu Dec 18 20:31:01 2014
@@ -0,0 +1,4 @@
+RUN: llvm-objdump -exports-trie %p/Inputs/macho-no-exports.dylib | FileCheck %s
+
+; Test that we don't crash with an empty export list.
+CHECK: macho-no-exports.dylib: file format Mach-O 64-bit x86-64





More information about the llvm-commits mailing list