From 40d25f33589a9db7a10f3390d7a792d559bd9f53 Mon Sep 17 00:00:00 2001 From: Simon Atanasyan Date: Tue, 2 Feb 2016 09:07:47 +0000 Subject: [PATCH] [ELF] Finalize .dynamic section at the end Some dynamic table tags like RELSZ and PLTRELSZ depens on result of finalizing corresponding relocation sections. Therefore we have to finalize .dynamic section at the end. Differential Revision: http://reviews.llvm.org/D16799 llvm-svn: 259478 --- lld/ELF/Writer.cpp | 12 +++++++++--- lld/test/ELF/mips-relocs.s | 9 +++++++-- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/lld/ELF/Writer.cpp b/lld/ELF/Writer.cpp index 5ab32f6..f9d0303 100644 --- a/lld/ELF/Writer.cpp +++ b/lld/ELF/Writer.cpp @@ -967,11 +967,17 @@ template bool Writer::createSections() { if (isOutputDynamic()) Out::DynSymTab->finalize(); - // Fill other section headers. The dynamic string table in finalized - // once the .dynamic finalizer has added a few last strings. + // Fill other section headers. The dynamic table is finalized + // at the end because some tags like RELSZ depend on result + // of finalizing other sections. The dynamic string table is + // finalized once the .dynamic finalizer has added a few last + // strings. See DynamicSection::finalize() for (OutputSectionBase *Sec : OutputSections) - if (Sec != Out::DynStrTab) + if (Sec != Out::DynStrTab && Sec != Out::Dynamic) Sec->finalize(); + + if (isOutputDynamic()) + Out::Dynamic->finalize(); return true; } diff --git a/lld/test/ELF/mips-relocs.s b/lld/test/ELF/mips-relocs.s index b05647a..987a6a4 100644 --- a/lld/test/ELF/mips-relocs.s +++ b/lld/test/ELF/mips-relocs.s @@ -4,13 +4,13 @@ # RUN: ld.lld -shared %t-be.o -o %t-be.so # RUN: llvm-objdump -t %t-be.so | FileCheck %s # RUN: llvm-objdump -s %t-be.so | FileCheck -check-prefix=BE %s -# RUN: llvm-readobj -relocations %t-be.so | FileCheck -check-prefix=REL %s +# RUN: llvm-readobj -r -dynamic-table %t-be.so | FileCheck -check-prefix=REL %s # RUN: llvm-mc -filetype=obj -triple=mipsel-unknown-linux %s -o %t-el.o # RUN: ld.lld -shared %t-el.o -o %t-el.so # RUN: llvm-objdump -t %t-el.so | FileCheck %s # RUN: llvm-objdump -s %t-el.so | FileCheck -check-prefix=EL %s -# RUN: llvm-readobj -relocations %t-el.so | FileCheck -check-prefix=REL %s +# RUN: llvm-readobj -r -dynamic-table %t-el.so | FileCheck -check-prefix=REL %s # REQUIRES: mips @@ -49,3 +49,8 @@ v2: # REL-NEXT: 0x30008 R_MIPS_REL32 - 0x0 # REL-NEXT: } # REL-NEXT: ] + +# REL: DynamicSection [ +# REL: Tag Type Name/Value +# REL: 0x00000012 RELSZ 16 (bytes) +# REL: 0x00000013 RELENT 8 (bytes) -- 2.7.4