From 04d208815c496cc530270707fbfd3e1991dce01d Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Tue, 21 Jul 2015 01:01:29 +0000 Subject: [PATCH] Don't do a walk over the dynamic table just to find DT_SONAME. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@242752 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Object/ELF.h | 23 ++++++++++------------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/include/llvm/Object/ELF.h b/include/llvm/Object/ELF.h index eed9bdd69e9..4ac49d419be 100644 --- a/include/llvm/Object/ELF.h +++ b/include/llvm/Object/ELF.h @@ -198,9 +198,8 @@ private: DynRegionInfo DynStrRegion; DynRegionInfo DynRelaRegion; - // Pointer to SONAME entry in dynamic string table - // This is set the first time getLoadName is called. - mutable const char *dt_soname = nullptr; + // SONAME entry in dynamic string table + StringRef DTSoname; // Records for each version index the corresponding Verdef or Vernaux entry. // This is filled the first time LoadVersionMap() is called. @@ -749,6 +748,7 @@ template void ELFFile::scanDynamicTable() { return this->base() + Phdr.p_offset + Delta; }; + uint64_t SONameOffset = 0; for (const Elf_Dyn &Dyn : dynamic_table()) { switch (Dyn.d_tag) { case ELF::DT_HASH: @@ -774,8 +774,14 @@ template void ELFFile::scanDynamicTable() { break; case ELF::DT_RELAENT: DynRelaRegion.EntSize = Dyn.getVal(); + break; + case ELF::DT_SONAME: + SONameOffset = Dyn.getVal(); + break; } } + if (SONameOffset) + DTSoname = getDynamicString(SONameOffset); } template @@ -826,16 +832,7 @@ ELFFile::dynamic_table_end() const { template StringRef ELFFile::getLoadName() const { - if (!dt_soname) { - dt_soname = ""; - // Find the DT_SONAME entry - for (const auto &Entry : dynamic_table()) - if (Entry.getTag() == ELF::DT_SONAME) { - dt_soname = getDynamicString(Entry.getVal()); - break; - } - } - return dt_soname; + return DTSoname; } template -- 2.34.1