x86: Add DT_PLTRELSZ/DT_PLTREL/DT_JMPREL for PLT relocation
authorH.J. Lu <hjl.tools@gmail.com>
Wed, 26 Apr 2017 22:34:00 +0000 (15:34 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Wed, 26 Apr 2017 22:34:00 +0000 (15:34 -0700)
x86, PLT relocation may contain R_386_TLS_DESC or R_X86_64_TLSDESC
even though there is no real PLT.  We need to add DT_PLTRELSZ, DT_PLTREL
and DT_JMPREL if there is a .rel.plt/.rela.plt section.

bfd/

* elf32-i386.c (elf_i386_size_dynamic_sections): Alwasys add
DT_PLTRELSZ, DT_PLTREL and DT_JMPREL for .rel.plt section.
* elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Alwasys
add DT_PLTRELSZ, DT_PLTREL and DT_JMPREL for .rela.plt section.

ld/

* testsuite/ld-i386/tlsdesc2.d: New test.
* testsuite/ld-x86-64/tlsdesc2.d: Likewise.

bfd/ChangeLog
bfd/elf32-i386.c
bfd/elf64-x86-64.c
ld/ChangeLog
ld/testsuite/ld-i386/i386.exp
ld/testsuite/ld-i386/tlsdesc2.d [new file with mode: 0644]
ld/testsuite/ld-x86-64/tlsdesc2.d [new file with mode: 0644]
ld/testsuite/ld-x86-64/x86-64.exp

index 26b3572c5b1355ceaf7143e897aaaa678f79012f..3234230075714c3cf4f8f5b0e424e5a87163164a 100644 (file)
@@ -1,3 +1,10 @@
+2017-04-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * elf32-i386.c (elf_i386_size_dynamic_sections): Alwasys add
+       DT_PLTRELSZ, DT_PLTREL and DT_JMPREL for .rel.plt section.
+       * elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Alwasys
+       add DT_PLTRELSZ, DT_PLTREL and DT_JMPREL for .rela.plt section.
+
 2017-04-26  Nick Clifton  <nickc@redhat.com>
 
        PR binutils/21434
index 9a568ce522b7362d6f61d1f447da2f0c554ad72d..78c5d5b9ddba353d19d8578b91ee0ae9ed29f7f5 100644 (file)
@@ -3577,14 +3577,14 @@ elf_i386_size_dynamic_sections (bfd *output_bfd, struct bfd_link_info *info)
             relocation.  */
          if (!add_dynamic_entry (DT_PLTGOT, 0))
            return FALSE;
+       }
 
-         if (htab->elf.srelplt->size != 0)
-           {
-             if (!add_dynamic_entry (DT_PLTRELSZ, 0)
-                 || !add_dynamic_entry (DT_PLTREL, DT_REL)
-                 || !add_dynamic_entry (DT_JMPREL, 0))
-               return FALSE;
-           }
+      if (htab->elf.srelplt->size != 0)
+       {
+         if (!add_dynamic_entry (DT_PLTRELSZ, 0)
+             || !add_dynamic_entry (DT_PLTREL, DT_REL)
+             || !add_dynamic_entry (DT_JMPREL, 0))
+           return FALSE;
        }
 
       if (relocs)
index 965ceb2f334480f4a9b6185286a03ad4c6beea23..0e0a020393f8f6bd6e5bffbbea347f5ba3819100 100644 (file)
@@ -4052,21 +4052,21 @@ elf_x86_64_size_dynamic_sections (bfd *output_bfd,
             relocation.  */
          if (!add_dynamic_entry (DT_PLTGOT, 0))
            return FALSE;
+       }
 
-         if (htab->elf.srelplt->size != 0)
-           {
-             if (!add_dynamic_entry (DT_PLTRELSZ, 0)
-                 || !add_dynamic_entry (DT_PLTREL, DT_RELA)
-                 || !add_dynamic_entry (DT_JMPREL, 0))
-               return FALSE;
-           }
-
-         if (htab->tlsdesc_plt
-             && (!add_dynamic_entry (DT_TLSDESC_PLT, 0)
-                 || !add_dynamic_entry (DT_TLSDESC_GOT, 0)))
+      if (htab->elf.srelplt->size != 0)
+       {
+         if (!add_dynamic_entry (DT_PLTRELSZ, 0)
+             || !add_dynamic_entry (DT_PLTREL, DT_RELA)
+             || !add_dynamic_entry (DT_JMPREL, 0))
            return FALSE;
        }
 
+      if (htab->tlsdesc_plt
+         && (!add_dynamic_entry (DT_TLSDESC_PLT, 0)
+             || !add_dynamic_entry (DT_TLSDESC_GOT, 0)))
+       return FALSE;
+
       if (relocs)
        {
          if (!add_dynamic_entry (DT_RELA, 0)
index 93165f2cbdc7686cd34bf4436cdba5ef5b7754ed..c93d903ef485bd358e0c9009141cfa112c800fbc 100644 (file)
@@ -1,3 +1,8 @@
+2017-04-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * testsuite/ld-i386/tlsdesc2.d: New test.
+       * testsuite/ld-x86-64/tlsdesc2.d: Likewise.
+
 2017-04-26  Maciej W. Rozycki  <macro@imgtec.com>
 
        PR ld/21334
index 844b36f50711414a5f16429150e32ee0a81c2efd..a709bcffab79fed270e5a587f5f0a322f3996f47 100644 (file)
@@ -437,6 +437,7 @@ run_dump_test "pr18801"
 run_dump_test "pr18815"
 run_dump_test "pr19939a"
 run_dump_test "pr19939b"
+run_dump_test "tlsdesc2"
 
 proc undefined_weak {cflags ldflags} {
     set testname "Undefined weak symbol"
diff --git a/ld/testsuite/ld-i386/tlsdesc2.d b/ld/testsuite/ld-i386/tlsdesc2.d
new file mode 100644 (file)
index 0000000..b8569e8
--- /dev/null
@@ -0,0 +1,10 @@
+#source: tlsdesc.s
+#as: --32
+#ld: -melf_i386 -shared -z now
+#readelf: -d --wide
+
+#...
+.*\(PLTRELSZ\).*
+.*\(PLTREL\).*
+.*\(JMPREL\).*
+#pass
diff --git a/ld/testsuite/ld-x86-64/tlsdesc2.d b/ld/testsuite/ld-x86-64/tlsdesc2.d
new file mode 100644 (file)
index 0000000..8679757
--- /dev/null
@@ -0,0 +1,10 @@
+#source: tlsdesc.s
+#as: --64
+#ld: -melf_x86_64 -shared -z now
+#readelf: -d --wide
+
+#...
+.*\(PLTRELSZ\).*
+.*\(PLTREL\).*
+.*\(JMPREL\).*
+#pass
index a9394c3a564d4494bdc1237b6578df152d2aef7b..7127eca02b087924f1dd5adb5dc8f0ad9c94b895 100644 (file)
@@ -530,6 +530,7 @@ run_dump_test "pr20253-4e"
 run_dump_test "pr20253-4f"
 run_dump_test "pr20253-5a"
 run_dump_test "pr20253-5b"
+run_dump_test "tlsdesc2"
 
 proc undefined_weak {cflags ldflags} {
     set testname "Undefined weak symbol"