From 0034320810df50a6176d5b06a47791582218bd36 Mon Sep 17 00:00:00 2001 From: Chingis Dugarzhapov Date: Wed, 9 Apr 2014 12:41:38 +0200 Subject: --set-soname, first working prototype --- src/patchelf.cc | 45 ++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 40 insertions(+), 5 deletions(-) diff --git a/src/patchelf.cc b/src/patchelf.cc index 74bf276..03eabf3 100644 --- a/src/patchelf.cc +++ b/src/patchelf.cc @@ -146,6 +146,8 @@ public: string getSoname(); + void setSoname(const string & newSoname); + void setInterpreter(const string & newInterpreter); typedef enum { rpPrint, rpShrink, rpSet } RPathOp; @@ -884,12 +886,11 @@ string ElfFile::getSoname() Elf_Shdr & shdrDynStr = findSection(".dynstr"); char * strTab = (char *) contents + rdi(shdrDynStr.sh_offset); - Elf_Dyn * dyn = (Elf_Dyn *) (contents + rdi(shdrDynamic.sh_offset)); - dyn = (Elf_Dyn *) (contents + rdi(shdrDynamic.sh_offset)); + Elf_Dyn * dynSoname = (Elf_Dyn *) (contents + rdi(shdrDynamic.sh_offset)); char * soname = 0; - for ( ; rdi(dyn->d_tag) != DT_NULL; dyn++) { - if (rdi(dyn->d_tag) == DT_SONAME) { - soname = strTab + rdi(dyn->d_un.d_val); + for ( ; rdi(dynSoname->d_tag) != DT_NULL; dynSoname++) { + if (rdi(dynSoname->d_tag) == DT_SONAME) { + soname = strTab + rdi(dynSoname->d_un.d_val); break; } } @@ -897,6 +898,29 @@ string ElfFile::getSoname() } template +void ElfFile::setSoname(const string & newSoname) +{ + debug("setting soname to `%s'\n", newSoname.c_str()); + Elf_Shdr & shdrDynStr = findSection(".dynstr"); + char * strTab = (char *) contents + rdi(shdrDynStr.sh_offset); + + Elf_Shdr & shdrDynamic = findSection(".dynamic"); + Elf_Dyn * dynSoname = (Elf_Dyn *) (contents + rdi(shdrDynamic.sh_offset)); + char * soname = 0; + for ( ; rdi(dynSoname->d_tag) != DT_NULL; dynSoname++) { + if (rdi(dynSoname->d_tag) == DT_SONAME) { + soname = strTab + rdi(dynSoname->d_un.d_val); + break; + } + } + if (strlen(soname) <= newSoname.size()) { + strcpy(soname, newSoname.c_str()); + changed = true; + return; + } +} + +template void ElfFile::setInterpreter(const string & newInterpreter) { string & section = replaceSection(".interp", newInterpreter.size() + 1); @@ -1115,6 +1139,8 @@ void ElfFile::removeNeeded(set libs) static bool printInterpreter = false; static bool printSoname = false; +static bool setSoname = false; +static string newSoname; static string newInterpreter; static bool shrinkRPath = false; @@ -1135,6 +1161,9 @@ static void patchElf2(ElfFile & elfFile, mode_t fileMode) if (printSoname) printf("%s\n", elfFile.getSoname().c_str()); + if (setSoname) + elfFile.setSoname(newSoname); + if (newInterpreter != "") elfFile.setInterpreter(newInterpreter); @@ -1195,6 +1224,7 @@ void showHelp(const string & progName) [--set-interpreter FILENAME]\n\ [--print-interpreter]\n\ [--print-soname]\n\ + [--set-soname]\n\ [--set-rpath RPATH]\n\ [--shrink-rpath]\n\ [--print-rpath]\n\ @@ -1228,6 +1258,11 @@ int main(int argc, char * * argv) else if (arg == "--print-soname") { printSoname = true; } + else if (arg == "--set-soname") { + if (++i == argc) error("missing argument"); + setSoname = true; + newSoname = argv[i]; + } else if (arg == "--shrink-rpath") { shrinkRPath = true; } -- cgit v0.12