OSDN Git Service

Handle the lack of a symbol table correctly.
authorStephen Hines <srhines@google.com>
Thu, 26 Jul 2018 20:05:31 +0000 (20:05 +0000)
committerStephen Hines <srhines@google.com>
Thu, 26 Jul 2018 20:05:31 +0000 (20:05 +0000)
Summary:
These two cases will trigger a dereference on a nullptr, since the
SymbolTable can be nonexistent for a given library, in addition to just
being empty.

Reviewers: alexshap

Reviewed By: alexshap

Subscribers: meikeb, kongyi, chh, jakehehrlich, llvm-commits, pirama

Differential Revision: https://reviews.llvm.org/D49534

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@338062 91177308-0d34-0410-b5e6-96231b3b80d8

test/tools/llvm-objcopy/strip-all.test
tools/llvm-objcopy/llvm-objcopy.cpp

index 71e024d..bc01835 100644 (file)
 # RUN: llvm-strip --strip-all %t8
 # RUN: cmp %t2 %t8
 
+# Verify that a non-existent symbol table (after first call to llvm-strip)
+# can be handled correctly.
+# RUN: cp %t %t9
+# RUN: llvm-strip --strip-all -keep=unavailable_symbol %t9
+# RUN: llvm-strip --strip-all -keep=unavailable_symbol %t9
+# RUN: cmp %t2 %t9
+
 !ELF
 FileHeader:
   Class:           ELFCLASS64
index 3a25e3f..4ccc67c 100644 (file)
@@ -396,7 +396,8 @@ static void HandleArgs(const CopyConfig &Config, Object &Obj,
       // Keep special sections.
       if (Obj.SectionNames == &Sec)
         return false;
-      if (Obj.SymbolTable == &Sec || Obj.SymbolTable->getStrTab() == &Sec)
+      if (Obj.SymbolTable == &Sec ||
+          (Obj.SymbolTable && Obj.SymbolTable->getStrTab() == &Sec))
         return false;
 
       // Remove everything else.
@@ -421,7 +422,7 @@ static void HandleArgs(const CopyConfig &Config, Object &Obj,
   // (equivalently, the updated symbol table is not empty)
   // the symbol table and the string table should not be removed.
   if ((!Config.SymbolsToKeep.empty() || Config.KeepFileSymbols) &&
-      !Obj.SymbolTable->empty()) {
+      Obj.SymbolTable && !Obj.SymbolTable->empty()) {
     RemovePred = [&Obj, RemovePred](const SectionBase &Sec) {
       if (&Sec == Obj.SymbolTable || &Sec == Obj.SymbolTable->getStrTab())
         return false;