cris: Don't generate unnecessary dynamic tags
authorH.J. Lu <hjl.tools@gmail.com>
Wed, 24 Jun 2020 11:00:19 +0000 (04:00 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Wed, 24 Jun 2020 11:00:31 +0000 (04:00 -0700)
Dynamic tags, DT_JMPREL, PLTREL and PLTRELSZ, are needed only if there
are relocation entries for PLT.  Don't generate them if there are no
relocation entries for PLT.

bfd/

PR ld/26083
* elf32-cris.c (elf_cris_size_dynamic_sections): Call
_bfd_elf_add_dynamic_tags.

ld/

PR ld/26083
* testsuite/ld-cris/libdso-15b.d: Updated.
* testsuite/ld-cris/libdso-1c.d: Likewise.
* testsuite/ld-cris/libdso-1d.d: Likewise.
* testsuite/ld-cris/libdso-15c.d: New file.

bfd/ChangeLog
bfd/elf32-cris.c
ld/ChangeLog
ld/testsuite/ld-cris/libdso-15b.d
ld/testsuite/ld-cris/libdso-15c.d [new file with mode: 0644]
ld/testsuite/ld-cris/libdso-1c.d
ld/testsuite/ld-cris/libdso-1d.d

index 9c202b27fc0635008510c6160158794bb8106f0e..f0d7414dc73bc85dec8455ca8877acd1ed15fa30 100644 (file)
@@ -1,3 +1,9 @@
+2020-06-24  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR ld/26083
+       * elf32-cris.c (elf_cris_size_dynamic_sections): Call
+       _bfd_elf_add_dynamic_tags.
+
 2020-06-24  Alan Modra  <amodra@gmail.com>
 
        * vms-alpha.c (_bfd_vms_slurp_etir <ETIR__C_OPR_ASH>): Implement
index bee7108684924e98b2fc5e83896cd43c06259b60..4360b5418c0ff273fc9cfc3b2827622eae0639b0 100644 (file)
@@ -3513,7 +3513,6 @@ elf_cris_size_dynamic_sections (bfd *output_bfd ATTRIBUTE_UNUSED,
   struct elf_cris_link_hash_table * htab;
   bfd *dynobj;
   asection *s;
-  bfd_boolean plt;
   bfd_boolean relocs;
 
   htab = elf_cris_hash_table (info);
@@ -3569,7 +3568,6 @@ elf_cris_size_dynamic_sections (bfd *output_bfd ATTRIBUTE_UNUSED,
   /* The check_relocs and adjust_dynamic_symbol entry points have
      determined the sizes of the various dynamic sections.  Allocate
      memory for them.  */
-  plt = FALSE;
   relocs = FALSE;
   for (s = dynobj->sections; s != NULL; s = s->next)
     {
@@ -3584,8 +3582,7 @@ elf_cris_size_dynamic_sections (bfd *output_bfd ATTRIBUTE_UNUSED,
 
       if (strcmp (name, ".plt") == 0)
        {
-         /* Remember whether there is a PLT.  */
-         plt = s->size != 0;
+         ;
        }
       else if (strcmp (name, ".got.plt") == 0)
        {
@@ -3650,49 +3647,7 @@ elf_cris_size_dynamic_sections (bfd *output_bfd ATTRIBUTE_UNUSED,
        return FALSE;
     }
 
-  if (elf_hash_table (info)->dynamic_sections_created)
-    {
-      /* Add some entries to the .dynamic section.  We fill in the
-        values later, in elf_cris_finish_dynamic_sections, but we
-        must add the entries now so that we get the correct size for
-        the .dynamic section.  The DT_DEBUG entry is filled in by the
-        dynamic linker and used by the debugger.  */
-#define add_dynamic_entry(TAG, VAL) \
-  _bfd_elf_add_dynamic_entry (info, TAG, VAL)
-
-      if (!bfd_link_pic (info))
-       {
-         if (!add_dynamic_entry (DT_DEBUG, 0))
-           return FALSE;
-       }
-
-      if (plt)
-       {
-         if (!add_dynamic_entry (DT_PLTGOT, 0)
-             || !add_dynamic_entry (DT_PLTRELSZ, 0)
-             || !add_dynamic_entry (DT_PLTREL, DT_RELA)
-             || !add_dynamic_entry (DT_JMPREL, 0))
-           return FALSE;
-       }
-
-      if (relocs)
-       {
-         if (!add_dynamic_entry (DT_RELA, 0)
-             || !add_dynamic_entry (DT_RELASZ, 0)
-             || !add_dynamic_entry (DT_RELAENT, sizeof (Elf32_External_Rela)))
-           return FALSE;
-       }
-
-      if ((info->flags & DF_TEXTREL) != 0)
-       {
-         if (!add_dynamic_entry (DT_TEXTREL, 0))
-           return FALSE;
-         info->flags |= DF_TEXTREL;
-       }
-    }
-#undef add_dynamic_entry
-
-  return TRUE;
+  return _bfd_elf_add_dynamic_tags (output_bfd, info, relocs);
 }
 
 /* This function is called via elf_cris_link_hash_traverse if we are
index fd0b98950e1c7193a215ebbfe0f30bd42e8092f6..47500a11b86c29698b9828c9fc14d3ffb9557bf4 100644 (file)
@@ -1,3 +1,11 @@
+2020-06-24  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR ld/26083
+       * testsuite/ld-cris/libdso-15b.d: Updated.
+       * testsuite/ld-cris/libdso-1c.d: Likewise.
+       * testsuite/ld-cris/libdso-1d.d: Likewise.
+       * testsuite/ld-cris/libdso-15c.d: New file.
+
 2020-06-24  H.J. Lu  <hongjiu.lu@intel.com>
 
        PR ld/26163
index 4e2bddb2522ab2f1da1dc8737ee9a45a87f86d44..39e001a9273edd071425e87646ca5ac04afe619b 100644 (file)
@@ -22,7 +22,7 @@ DYNAMIC SYMBOL TABLE:
 0+[     ]+DF \*UND\*[   ]+0+  TST3[     ]+expfn2
 #...
 Contents of section .rela.dyn:
- 017c a4220000 0a040000 00000000 a8220000  .*
+ 017c 8c220000 0a040000 00000000 90220000  .*
  018c 0a050000 00000000                    .*
 Contents of section .plt:
  0194 fce17e7e 0401307a 08013009 00000000  .*
@@ -34,5 +34,5 @@ Contents of section .text:
  01e0 00006fae d4ffffff                    .*
 #...
 Contents of section .got:
- 2298 e8210000 00000000 00000000 00000000  .*
- 22a8 00000000                             .*
+ 2280 e8210000 00000000 00000000 00000000  .*
+ 2290 00000000                             .*
diff --git a/ld/testsuite/ld-cris/libdso-15c.d b/ld/testsuite/ld-cris/libdso-15c.d
new file mode 100644 (file)
index 0000000..b035990
--- /dev/null
@@ -0,0 +1,22 @@
+#source: expdref2.s
+#as: --pic --no-underscore --em=criself
+#ld: --shared -m crislinux --hash-style=sysv
+#ld_after_inputfiles: tmpdir/libdso-15.so
+#readelf: -d
+
+Dynamic section at offset 0x1e8 contains 14 entries:
+  Tag        Type                         Name/Value
+ 0x00000001 \(NEEDED\)                     Shared library: \[tmpdir/libdso-15.so\]
+ 0x00000004 \(HASH\)                       0x94
+ 0x00000005 \(STRTAB\)                     0x120
+ 0x00000006 \(SYMTAB\)                     0xc0
+ 0x0000000a \(STRSZ\)                      45 \(bytes\)
+ 0x0000000b \(SYMENT\)                     16 \(bytes\)
+ 0x00000003 \(PLTGOT\)                     0x2280
+ 0x00000007 \(RELA\)                       0x17c
+ 0x00000008 \(RELASZ\)                     24 \(bytes\)
+ 0x00000009 \(RELAENT\)                    12 \(bytes\)
+ 0x6ffffffe \(VERNEED\)                    0x15c
+ 0x6fffffff \(VERNEEDNUM\)                 1
+ 0x6ffffff0 \(VERSYM\)                     0x14e
+ 0x00000000 \(NULL\)                       0x0
index f02dc5e44629ed4da565b628396efad1acbde00b..2b9b13b660b6f04de836b43f0a0460715807c1e7 100644 (file)
@@ -19,7 +19,7 @@ DYNAMIC SYMBOL TABLE:
 0+[    ]+DF \*UND\*    0+[     ]+TST2[  ]+expfn
 #...
 Contents of section .rela.dyn:
- 0140 68220000 0a020000 00000000 6c220000  .*
+ 0140 50220000 0a020000 00000000 54220000  .*
  0150 0a030000 00000000                    .*
 Contents of section .plt:
  0158 fce17e7e 0401307a 08013009 00000000  .*
@@ -31,5 +31,5 @@ Contents of section .text:
  01a4 00006fae d4ffffff                    .*
 #...
 Contents of section .got:
- 225c ac210000 00000000 00000000 00000000  .*
- 226c 00000000                             .*
+ 2244 ac210000 00000000 00000000 00000000  .*
+ 2254 00000000                             .*
index 06e72fc2797020f02b1562d1068de5e727c01501..83a43372edb28a3fe78d70962593cb189901da7b 100644 (file)
 DYNAMIC SYMBOL TABLE:
 #...
 0+1a6  w   DF .text    0+2 expfn
-0+2254  w   DO .data   0+4 expobj
+0+223c  w   DO .data   0+4 expobj
 #...
 Contents of section .rela.dyn:
- 0138 4c220000 0a020000 00000000 50220000  .*
+ 0138 34220000 0a020000 00000000 38220000  .*
  0148 0a030000 00000000                    .*
 Contents of section .plt:
  0150 fce17e7e 0401307a 08013009 00000000  .*
@@ -30,7 +30,7 @@ Contents of section .text:
 Contents of section .dynamic:
 #...
 Contents of section .got:
- 2240 a8210000 00000000 00000000 00000000  .*
- 2250 00000000                             .*
+ 2228 a8210000 00000000 00000000 00000000  .*
+ 2238 00000000                             .*
 Contents of section .data:
- 2254 00000000                             .*
+ 223c 00000000                             .*