[llvm] 30ccee7 - [llvm-objcopy][MachO] Implement --strip-debug

Fangrui Song via llvm-commits llvm-commits at lists.llvm.org
Thu Nov 21 09:41:17 PST 2019


Author: Fangrui Song
Date: 2019-11-21T09:40:34-08:00
New Revision: 30ccee71ca0218248c39768102488ef589ea9c1b

URL: https://github.com/llvm/llvm-project/commit/30ccee71ca0218248c39768102488ef589ea9c1b
DIFF: https://github.com/llvm/llvm-project/commit/30ccee71ca0218248c39768102488ef589ea9c1b.diff

LOG: [llvm-objcopy][MachO] Implement --strip-debug

Reviewed By: alexshap

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

Added: 
    llvm/test/tools/llvm-objcopy/MachO/strip-debug.test

Modified: 
    llvm/tools/llvm-objcopy/MachO/MachOObjcopy.cpp

Removed: 
    


################################################################################
diff  --git a/llvm/test/tools/llvm-objcopy/MachO/strip-debug.test b/llvm/test/tools/llvm-objcopy/MachO/strip-debug.test
new file mode 100644
index 000000000000..d53271ba31e5
--- /dev/null
+++ b/llvm/test/tools/llvm-objcopy/MachO/strip-debug.test
@@ -0,0 +1,38 @@
+## Show that llvm-objcopy/llvm-strip removes all symbols and debug sections.
+
+# RUN: yaml2obj %p/Inputs/strip-all-with-dwarf.yaml -o %t
+
+# RUN: llvm-objcopy --strip-debug %t %t.stripped
+# RUN: llvm-readobj --sections %t.stripped | FileCheck /dev/null --check-prefix=NODWARF \
+# RUN:   --implicit-check-not='Name: __debug' --implicit-check-not='Name: __apple'
+
+## Make sure that all symbols are kept.
+# RUN: llvm-readobj --symbols %t | FileCheck %s --check-prefix=SYM
+# RUN: llvm-readobj --symbols %t.stripped | FileCheck %s --check-prefix=SYM
+
+# SYM:         Symbols [
+# SYM-COUNT-3: Symbol
+# SYM:         ]
+
+## Make sure that all relocations to non-debug sections are kept.
+# RUN: llvm-readobj -r %t | FileCheck %s --check-prefixes=RELOC,DEBUG
+# RUN: llvm-readobj -r %t.stripped | FileCheck %s --check-prefix=RELOC
+
+# RELOC:      Relocations [
+# RELOC-NEXT:   Section __text {
+# RELOC-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# RELOC-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# RELOC-NEXT:   }
+# DEBUG:        Section __debug_info {
+# DEBUG-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# DEBUG-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# DEBUG-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# DEBUG-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# DEBUG-NEXT:   }
+# RELOC-NEXT:   Section __compact_unwind {
+# RELOC-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# RELOC-NEXT:   }
+# DEBUG-NEXT:   Section __debug_line {
+# DEBUG-NEXT:     0x0 0 0 0 X86_64_RELOC_UNSIGNED 0 -
+# DEBUG-NEXT:   }
+# RELOC-NEXT: ]

diff  --git a/llvm/tools/llvm-objcopy/MachO/MachOObjcopy.cpp b/llvm/tools/llvm-objcopy/MachO/MachOObjcopy.cpp
index e589674471db..1f68fda2392d 100644
--- a/llvm/tools/llvm-objcopy/MachO/MachOObjcopy.cpp
+++ b/llvm/tools/llvm-objcopy/MachO/MachOObjcopy.cpp
@@ -29,7 +29,7 @@ static void removeSections(const CopyConfig &Config, Object &Obj) {
     };
   }
 
-  if (Config.StripAll) {
+  if (Config.StripAll || Config.StripDebug) {
     // Remove all debug sections.
     RemovePred = [RemovePred](const Section &Sec) {
       if (Sec.Segname == "__DWARF")
@@ -99,8 +99,8 @@ static Error handleArgs(const CopyConfig &Config, Object &Obj) {
       Config.ExtractDWO || Config.KeepFileSymbols || Config.LocalizeHidden ||
       Config.PreserveDates || Config.StripAllGNU || Config.StripDWO ||
       Config.StripNonAlloc || Config.StripSections || Config.Weaken ||
-      Config.DecompressDebugSections || Config.StripDebug ||
-      Config.StripNonAlloc || Config.StripSections || Config.StripUnneeded ||
+      Config.DecompressDebugSections || Config.StripNonAlloc ||
+      Config.StripSections || Config.StripUnneeded ||
       Config.DiscardMode != DiscardType::None || !Config.SymbolsToAdd.empty() ||
       Config.EntryExpr) {
     return createStringError(llvm::errc::invalid_argument,


        


More information about the llvm-commits mailing list