From 49011d2b65346acfa2ddffb315134bef149719a2 Mon Sep 17 00:00:00 2001 From: Alexander Shaposhnikov Date: Wed, 23 May 2018 19:44:19 +0000 Subject: [PATCH] [llvm-strip] Expose --keep-symbol option Expose --keep-symbol option in llvm-strip. Test plan: make check-all Differential revision: https://reviews.llvm.org/D47222 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@333117 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/tools/llvm-objcopy/strip-all-and-keep-symbol.test | 8 ++++++++ tools/llvm-objcopy/StripOpts.td | 7 +++++++ tools/llvm-objcopy/llvm-objcopy.cpp | 3 +++ 3 files changed, 18 insertions(+) diff --git a/test/tools/llvm-objcopy/strip-all-and-keep-symbol.test b/test/tools/llvm-objcopy/strip-all-and-keep-symbol.test index 6cb5f855b55..c0f22b489b1 100644 --- a/test/tools/llvm-objcopy/strip-all-and-keep-symbol.test +++ b/test/tools/llvm-objcopy/strip-all-and-keep-symbol.test @@ -1,7 +1,15 @@ # RUN: yaml2obj %s > %t +# RUN: cp %t %t1 # RUN: llvm-objcopy --strip-all --keep-symbol foo %t %t2 # RUN: llvm-readobj -sections -symbols %t2 | FileCheck %s +# Verify that the first run of llvm-objcopy +# has not modified the input binary. +# RUN: cmp %t %t1 + +# RUN: llvm-strip -keep-symbol=foo %t1 +# RUN: cmp %t1 %t2 + !ELF FileHeader: Class: ELFCLASS64 diff --git a/tools/llvm-objcopy/StripOpts.td b/tools/llvm-objcopy/StripOpts.td index 1d7a1aec14d..7c8862f5406 100644 --- a/tools/llvm-objcopy/StripOpts.td +++ b/tools/llvm-objcopy/StripOpts.td @@ -16,3 +16,10 @@ defm remove_section : Eq<"remove-section">, def R : JoinedOrSeparate<["-"], "R">, Alias; + +defm keep_symbol : Eq<"keep-symbol">, + MetaVarName<"symbol">, + HelpText<"Do not remove symbol ">; + +def K : JoinedOrSeparate<["-"], "K">, + Alias; diff --git a/tools/llvm-objcopy/llvm-objcopy.cpp b/tools/llvm-objcopy/llvm-objcopy.cpp index dbe8f8c10ac..6aac11af1bb 100644 --- a/tools/llvm-objcopy/llvm-objcopy.cpp +++ b/tools/llvm-objcopy/llvm-objcopy.cpp @@ -557,6 +557,9 @@ CopyConfig ParseStripOptions(ArrayRef ArgsArr) { for (auto Arg : InputArgs.filtered(STRIP_remove_section)) Config.ToRemove.push_back(Arg->getValue()); + + for (auto Arg : InputArgs.filtered(STRIP_keep_symbol)) + Config.SymbolsToKeep.push_back(Arg->getValue()); return Config; } -- 2.11.0