From: George Rimar Date: Mon, 18 Feb 2019 13:58:12 +0000 (+0000) Subject: [llvm-readobj] - Simplify .gnu.version_d dumping. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3d4666cd74d3aaab54ce4076ae92b119cfe101ba;p=llvm [llvm-readobj] - Simplify .gnu.version_d dumping. This is similar to D58048. Instead of scanning the dynamic table to read the DT_VERDEFNUM, we could take it from the sh_info field. (https://docs.oracle.com/cd/E19683-01/816-1386/chapter6-94076/index.html) The patch does this. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@354270 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/llvm-readobj/ELFDumper.cpp b/tools/llvm-readobj/ELFDumper.cpp index dc6e44819aa..9a0d909120d 100644 --- a/tools/llvm-readobj/ELFDumper.cpp +++ b/tools/llvm-readobj/ELFDumper.cpp @@ -652,16 +652,6 @@ static void printVersionDefinitionSection(ELFDumper *Dumper, if (!Sec) return; - // The number of entries in the section SHT_GNU_verdef - // is determined by DT_VERDEFNUM tag. - unsigned VerDefsNum = 0; - for (const typename ELFO::Elf_Dyn &Dyn : Dumper->dynamic_table()) { - if (Dyn.d_tag == DT_VERDEFNUM) { - VerDefsNum = Dyn.d_un.d_val; - break; - } - } - const uint8_t *SecStartAddress = (const uint8_t *)Obj->base() + Sec->sh_offset; const uint8_t *SecEndAddress = SecStartAddress + Sec->sh_size; @@ -669,6 +659,7 @@ static void printVersionDefinitionSection(ELFDumper *Dumper, const typename ELFO::Elf_Shdr *StrTab = unwrapOrError(Obj->getSection(Sec->sh_link)); + unsigned VerDefsNum = Sec->sh_info; while (VerDefsNum--) { if (P + sizeof(VerDef) > SecEndAddress) report_fatal_error("invalid offset in the section");