summaryrefslogtreecommitdiffstats
path: root/llvm/tools/llvm-objcopy/llvm-objcopy.cpp
diff options
context:
space:
mode:
authorPaul Semel <semelpaul@gmail.com>2018-05-26 08:10:37 +0000
committerPaul Semel <semelpaul@gmail.com>2018-05-26 08:10:37 +0000
commitcf51c80bf1adfa3bb2eb0ac5a8990a076b4c7256 (patch)
tree4f0c6ebfc9880e0ce7e7a9e70e8759a0e0eb8782 /llvm/tools/llvm-objcopy/llvm-objcopy.cpp
parentfb89e7a943bb4cf32a9b61817654b735ff737dc3 (diff)
downloadbcm5719-llvm-cf51c80bf1adfa3bb2eb0ac5a8990a076b4c7256.tar.gz
bcm5719-llvm-cf51c80bf1adfa3bb2eb0ac5a8990a076b4c7256.zip
[llvm-objcopy] Add --keep-file-symbols option
This option prevent from removing file symbols while removing symbols. Differential Revision: https://reviews.llvm.org/D46830 llvm-svn: 333339
Diffstat (limited to 'llvm/tools/llvm-objcopy/llvm-objcopy.cpp')
-rw-r--r--llvm/tools/llvm-objcopy/llvm-objcopy.cpp10
1 files changed, 7 insertions, 3 deletions
diff --git a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp
index 0a5b5b0d066..da8c6ee776a 100644
--- a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp
+++ b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp
@@ -174,6 +174,7 @@ struct CopyConfig {
bool Weaken = false;
bool DiscardAll = false;
bool OnlyKeepDebug = false;
+ bool KeepFileSymbols = false;
};
using SectionPred = std::function<bool(const SectionBase &Sec)>;
@@ -273,8 +274,9 @@ void HandleArgs(const CopyConfig &Config, Object &Obj, const Reader &Reader,
}
Obj.removeSymbols([&](const Symbol &Sym) {
- if (!Config.SymbolsToKeep.empty() &&
- is_contained(Config.SymbolsToKeep, Sym.Name))
+ if ((!Config.SymbolsToKeep.empty() &&
+ is_contained(Config.SymbolsToKeep, Sym.Name)) ||
+ (Config.KeepFileSymbols && Sym.Type == STT_FILE))
return false;
if (Config.DiscardAll && Sym.Binding == STB_LOCAL &&
@@ -410,7 +412,8 @@ void HandleArgs(const CopyConfig &Config, Object &Obj, const Reader &Reader,
// and at least one of those symbols is present
// (equivalently, the updated symbol table is not empty)
// the symbol table and the string table should not be removed.
- if (!Config.SymbolsToKeep.empty() && !Obj.SymbolTable->empty()) {
+ if ((!Config.SymbolsToKeep.empty() || Config.KeepFileSymbols) &&
+ !Obj.SymbolTable->empty()) {
RemovePred = [&Obj, RemovePred](const SectionBase &Sec) {
if (&Sec == Obj.SymbolTable || &Sec == Obj.SymbolTable->getStrTab())
return false;
@@ -531,6 +534,7 @@ CopyConfig ParseObjcopyOptions(ArrayRef<const char *> ArgsArr) {
Config.Weaken = InputArgs.hasArg(OBJCOPY_weaken);
Config.DiscardAll = InputArgs.hasArg(OBJCOPY_discard_all);
Config.OnlyKeepDebug = InputArgs.hasArg(OBJCOPY_only_keep_debug);
+ Config.KeepFileSymbols = InputArgs.hasArg(OBJCOPY_keep_file_symbols);
for (auto Arg : InputArgs.filtered(OBJCOPY_localize_symbol))
Config.SymbolsToLocalize.push_back(Arg->getValue());
for (auto Arg : InputArgs.filtered(OBJCOPY_globalize_symbol))
OpenPOWER on IntegriCloud