xtensa: fix relaxation of undefined weak references in shared objects
authorMax Filippov <jcmvbkbc@gmail.com>
Sun, 22 Jul 2018 20:52:28 +0000 (13:52 -0700)
committerMax Filippov <jcmvbkbc@gmail.com>
Mon, 23 Jul 2018 19:02:53 +0000 (12:02 -0700)
The change c451bb34ae8b ("xtensa: don't emit dynamic relocation for weak
undefined symbol") didn't properly handle shrinking of relocation
sections due to coalescing of references to a dynamic undefined weak
symbol in a shared object, which resulted in the following assertion
failure in ld when linking uClibc-ng libthread_db for xtensa:

  BFD (GNU Binutils) 2.31 internal error, aborting at elf32-xtensa.c:3269
  in elf_xtensa_finish_dynamic_sections

Shrink dynamic relocations section for dynamic undefined weak symbols
when linking a shared object.

bfd/
2018-07-23  Max Filippov  <jcmvbkbc@gmail.com>

* elf32-xtensa.c (shrink_dynamic_reloc_sections): Shrink dynamic
relocations section for dynamic undefined weak symbols when
linking a shared object.

bfd/ChangeLog
bfd/elf32-xtensa.c

index 19fd9df2cb925427067205d7422421ecae9e62f9..3bdd2aa254bc990857922f054dad3e09f3a9a14d 100644 (file)
@@ -1,3 +1,9 @@
+2018-07-23  Max Filippov  <jcmvbkbc@gmail.com>
+
+       * elf32-xtensa.c (shrink_dynamic_reloc_sections): Shrink dynamic
+       relocations section for dynamic undefined weak symbols when
+       linking a shared object.
+
 2018-07-23  Tom Tromey  <tom@tromey.com>
 
        * elf.c (bfd_get_elf_phdrs): Don't call memcpy with size 0.
index f7f569d0c0868b529c4e6bef6660240406eeaeaf..a4b046e445f1d37e2c015c888083d415b1ec7ae7 100644 (file)
@@ -10022,7 +10022,8 @@ shrink_dynamic_reloc_sections (struct bfd_link_info *info,
   if ((r_type == R_XTENSA_32 || r_type == R_XTENSA_PLT)
       && (input_section->flags & SEC_ALLOC) != 0
       && (dynamic_symbol || bfd_link_pic (info))
-      && (!h || h->root.type != bfd_link_hash_undefweak))
+      && (!h || h->root.type != bfd_link_hash_undefweak
+         || (dynamic_symbol && bfd_link_dll (info))))
     {
       asection *srel;
       bfd_boolean is_plt = FALSE;