diff options
author | Jake Ehrlich <jakehehrlich@google.com> | 2017-11-13 22:02:07 +0000 |
---|---|---|
committer | Jake Ehrlich <jakehehrlich@google.com> | 2017-11-13 22:02:07 +0000 |
commit | fabddf18a0d195802168aeec21ec35cc6989e584 (patch) | |
tree | 209d1a94b621545d129c7366799f6ede09c09e76 /llvm/tools/llvm-objcopy/llvm-objcopy.cpp | |
parent | 9fd33f249f6ad3f845cf2d0f6210d3f70b823bc4 (diff) | |
download | bcm5719-llvm-fabddf18a0d195802168aeec21ec35cc6989e584.tar.gz bcm5719-llvm-fabddf18a0d195802168aeec21ec35cc6989e584.zip |
[llvm-objcopy] Add --strip-all option to llvm-objcopy
This change adds a slightly less extreme form of stripping. It should
remove any section that starts with ".debug" and should remove any
symbol table or relocations. In general this strips out most of the
stuff you don't need to execute but leaves a number of things around.
This behavior has been designed to be compatible with GNU strip/objcopy
--strip-all so that anywhere you currently use --strip-all you should be
able to use llvm-objcopy as a drop in replacement.
Differential Revision: https://reviews.llvm.org/D39769
llvm-svn: 318092
Diffstat (limited to 'llvm/tools/llvm-objcopy/llvm-objcopy.cpp')
-rw-r--r-- | llvm/tools/llvm-objcopy/llvm-objcopy.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp index 54186f63c07..12d6205722f 100644 --- a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp +++ b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp @@ -81,6 +81,8 @@ static cl::list<std::string> ToRemove("remove-section", cl::desc("Remove a specific section")); static cl::alias ToRemoveA("R", cl::desc("Alias for remove-section"), cl::aliasopt(ToRemove)); +static cl::opt<bool> StripAll("strip-all", + cl::desc("Removes symbol, relocation, and debug information")); static cl::opt<bool> StripSections("strip-sections", cl::desc("Remove all section headers")); static cl::opt<bool> @@ -170,6 +172,24 @@ void CopyBinary(const ELFObjectFile<ELF64LE> &ObjFile) { return OnlyKeepDWOPred(*Obj, Sec) || RemovePred(Sec); }; + if (StripAll) + RemovePred = [RemovePred, &Obj](const SectionBase &Sec) { + if (RemovePred(Sec)) + return true; + if ((Sec.Flags & SHF_ALLOC) != 0) + return false; + if (&Sec == Obj->getSectionHeaderStrTab()) + return false; + switch(Sec.Type) { + case SHT_SYMTAB: + case SHT_REL: + case SHT_RELA: + case SHT_STRTAB: + return true; + } + return Sec.Name.startswith(".debug"); + }; + if (StripSections) { RemovePred = [RemovePred](const SectionBase &Sec) { return RemovePred(Sec) || (Sec.Flags & SHF_ALLOC) == 0; |