Skip to content

Commit

Permalink
[llvm-strip] Hook up (unimplemented) --only-keep-debug
Browse files Browse the repository at this point in the history
For ELF, we accept but ignore --only-keep-debug. Do the same for llvm-strip.

COFF does implement this, so update the test that it is supported.

llvm-svn: 356207
  • Loading branch information
rupprecht committed Mar 14, 2019
1 parent 0b31b24 commit 12ed01d
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 1 deletion.
4 changes: 4 additions & 0 deletions llvm/test/tools/llvm-objcopy/COFF/only-keep-debug.test
Expand Up @@ -3,6 +3,10 @@ RUN: yaml2obj %p/Inputs/only-keep-sections.yaml > %t.in.exe
RUN: llvm-objcopy --only-keep-debug %t.in.exe %t.out.exe
RUN: llvm-readobj --sections %t.out.exe | FileCheck %s --check-prefix=SECTIONS
RUN: llvm-objdump -t %t.out.exe | FileCheck %s --check-prefix=SYMBOLS
# Run llvm-strip with --strip-symbol on a non-existent symbol to prevent
# defaulting to --strip-all.
RUN: llvm-strip --only-keep-debug --strip-symbol foo %t.in.exe -o %t-strip.out.exe
RUN: cmp %t.out.exe %t-strip.out.exe

Check that all non-debug/buildid sections with IMAGE_SCN_CNT_CODE
or IMAGE_SCN_CNT_INITIALIZED_DATA are truncated, and no others.
Expand Down
4 changes: 4 additions & 0 deletions llvm/test/tools/llvm-objcopy/ELF/basic-only-keep-debug.test
Expand Up @@ -6,6 +6,10 @@
# RUN: llvm-objcopy %t %t2
# RUN: llvm-objcopy --only-keep-debug %t %t3
# RUN: cmp %t2 %t3
# Run llvm-strip with --strip-symbol on a non-existent symbol to prevent
# defaulting to --strip-all.
# RUN: llvm-strip --only-keep-debug --strip-symbol foo %t -o %t4
# RUN: cmp %t2 %t4

!ELF
FileHeader:
Expand Down
1 change: 1 addition & 0 deletions llvm/tools/llvm-objcopy/CopyConfig.cpp
Expand Up @@ -725,6 +725,7 @@ Expected<DriverConfig> parseStripOptions(ArrayRef<const char *> ArgsArr) {
Config.StripUnneeded = InputArgs.hasArg(STRIP_strip_unneeded);
Config.StripAll = InputArgs.hasArg(STRIP_strip_all);
Config.StripAllGNU = InputArgs.hasArg(STRIP_strip_all_gnu);
Config.OnlyKeepDebug = InputArgs.hasArg(STRIP_only_keep_debug);
Config.KeepFileSymbols = InputArgs.hasArg(STRIP_keep_file_symbols);

for (auto Arg : InputArgs.filtered(STRIP_keep_section))
Expand Down
5 changes: 4 additions & 1 deletion llvm/tools/llvm-objcopy/ObjcopyOpts.td
Expand Up @@ -206,9 +206,12 @@ def N : JoinedOrSeparate<["-"], "N">, Alias<strip_symbol>;
defm keep_symbol : Eq<"keep-symbol", "Do not remove symbol <symbol>">,
MetaVarName<"symbol">;
def K : JoinedOrSeparate<["-"], "K">, Alias<keep_symbol>;

def only_keep_debug
: Flag<["-", "--"], "only-keep-debug">,
HelpText<"Currently ignored. Only for compatibility with GNU objcopy.">;
HelpText<"Clear sections that would not be stripped by --strip-debug. "
"Currently only implemented for COFF.">;

def keep_file_symbols : Flag<["-", "--"], "keep-file-symbols">,
HelpText<"Do not remove file symbols">;
defm dump_section
Expand Down
5 changes: 5 additions & 0 deletions llvm/tools/llvm-objcopy/StripOpts.td
Expand Up @@ -63,6 +63,11 @@ def keep_file_symbols : Flag<["-", "--"], "keep-file-symbols">,

def K : JoinedOrSeparate<["-"], "K">, Alias<keep_symbol>;

def only_keep_debug
: Flag<["-", "--"], "only-keep-debug">,
HelpText<"Clear sections that would not be stripped by --strip-debug. "
"Currently only implemented for COFF.">;

def discard_locals : Flag<["-", "--"], "discard-locals">,
HelpText<"Remove compiler-generated local symbols, (e.g. "
"symbols starting with .L)">;
Expand Down

0 comments on commit 12ed01d

Please sign in to comment.