diff options
author | Paul Semel <semelpaul@gmail.com> | 2018-04-27 19:16:27 +0000 |
---|---|---|
committer | Paul Semel <semelpaul@gmail.com> | 2018-04-27 19:16:27 +0000 |
commit | 3a8a56b8b76a39c24110fc92fc24bbd0549f737e (patch) | |
tree | 89ba2b068988b3290304843531978a93bc9edfc6 /llvm/tools/llvm-objcopy/llvm-objcopy.cpp | |
parent | 1865df49960e34cc90d0083b0e0cd4771c0feb35 (diff) | |
download | bcm5719-llvm-3a8a56b8b76a39c24110fc92fc24bbd0549f737e.tar.gz bcm5719-llvm-3a8a56b8b76a39c24110fc92fc24bbd0549f737e.zip |
[llvm-objcopy] Add --weaken-symbol (-W) option
llvm-svn: 331070
Diffstat (limited to 'llvm/tools/llvm-objcopy/llvm-objcopy.cpp')
-rw-r--r-- | llvm/tools/llvm-objcopy/llvm-objcopy.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp index 59b07828cbd..4dd8d36ee08 100644 --- a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp +++ b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp @@ -120,6 +120,7 @@ struct CopyConfig { std::vector<StringRef> AddSection; std::vector<StringRef> SymbolsToLocalize; std::vector<StringRef> SymbolsToGlobalize; + std::vector<StringRef> SymbolsToWeaken; StringMap<StringRef> SymbolsToRename; bool StripAll; bool StripAllGNU; @@ -328,6 +329,11 @@ void HandleArgs(const CopyConfig &Config, Object &Obj, const Reader &Reader, is_contained(Config.SymbolsToGlobalize, Sym.Name)) Sym.Binding = STB_GLOBAL; + if (!Config.SymbolsToWeaken.empty() && + is_contained(Config.SymbolsToWeaken, Sym.Name) && + Sym.Binding == STB_GLOBAL) + Sym.Binding = STB_WEAK; + const auto I = Config.SymbolsToRename.find(Sym.Name); if (I != Config.SymbolsToRename.end()) Sym.Name = I->getValue(); @@ -421,6 +427,8 @@ CopyConfig ParseObjcopyOptions(ArrayRef<const char *> ArgsArr) { Config.SymbolsToLocalize.push_back(Arg->getValue()); for (auto Arg : InputArgs.filtered(OBJCOPY_globalize_symbol)) Config.SymbolsToGlobalize.push_back(Arg->getValue()); + for (auto Arg : InputArgs.filtered(OBJCOPY_weaken_symbol)) + Config.SymbolsToWeaken.push_back(Arg->getValue()); return Config; } |