[Object] Don't crash on empty export lists.
authorJuergen Ributzka <juergen@apple.com>
Fri, 19 Dec 2014 02:31:01 +0000 (02:31 +0000)
committerJuergen Ributzka <juergen@apple.com>
Fri, 19 Dec 2014 02:31:01 +0000 (02:31 +0000)
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

llvm-svn: 224563

llvm/lib/Object/MachOObjectFile.cpp
llvm/test/Object/Inputs/macho-no-exports.dylib [new file with mode: 0755]
llvm/test/Object/objdump-export-list.test [new file with mode: 0644]

index fd086af..92981fe 100644 (file)
@@ -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();
diff --git a/llvm/test/Object/Inputs/macho-no-exports.dylib b/llvm/test/Object/Inputs/macho-no-exports.dylib
new file mode 100755 (executable)
index 0000000..6e1be6c
Binary files /dev/null and b/llvm/test/Object/Inputs/macho-no-exports.dylib differ
diff --git a/llvm/test/Object/objdump-export-list.test b/llvm/test/Object/objdump-export-list.test
new file mode 100644 (file)
index 0000000..74344c1
--- /dev/null
@@ -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