Blame SOURCES/binutils-keep-weak-aliases.patch

68d1de
--- binutils.orig/bfd/elflink.c	2020-02-18 17:32:29.506802884 +0000
68d1de
+++ binutils-2.32/bfd/elflink.c	2020-02-18 17:34:09.783017828 +0000
68d1de
@@ -12988,6 +12988,7 @@ _bfd_elf_gc_mark_rsec (struct bfd_link_i
68d1de
 {
68d1de
   unsigned long r_symndx;
68d1de
   struct elf_link_hash_entry *h;
68d1de
+  struct elf_link_hash_entry *hw;
68d1de
 
68d1de
   r_symndx = cookie->rel->r_info >> cookie->r_sym_shift;
68d1de
   if (r_symndx == STN_UNDEF)
68d1de
@@ -13007,12 +13008,16 @@ _bfd_elf_gc_mark_rsec (struct bfd_link_i
68d1de
 	     || h->root.type == bfd_link_hash_warning)
68d1de
 	h = (struct elf_link_hash_entry *) h->root.u.i.link;
68d1de
       h->mark = 1;
68d1de
-      /* If this symbol is weak and there is a non-weak definition, we
68d1de
-	 keep the non-weak definition because many backends put
68d1de
-	 dynamic reloc info on the non-weak definition for code
68d1de
-	 handling copy relocs.  */
68d1de
-      if (h->is_weakalias)
68d1de
-	weakdef (h)->mark = 1;
68d1de
+      /* Keep all aliases of the symbol too.  If an object symbol
68d1de
+        needs to be copied into .dynbss then all of its aliases
68d1de
+        should be present as dynamic symbols, not just the one used
68d1de
+        on the copy relocation.  */
68d1de
+      hw = h;
68d1de
+      while (hw->is_weakalias)
68d1de
+       {
68d1de
+         hw = hw->u.alias;
68d1de
+         hw->mark = 1;
68d1de
+       }
68d1de
 
68d1de
       if (start_stop != NULL)
68d1de
 	{