Indirect and warning symbols
authorAlan Modra <amodra@gmail.com>
Sat, 3 Dec 2016 10:27:27 +0000 (20:57 +1030)
committerAlan Modra <amodra@gmail.com>
Sat, 3 Dec 2016 10:27:27 +0000 (20:57 +1030)
It's possible but unlikely that an indirect symbol points at a warning
symbol.

* elf64-ppc.c (add_symbol_adjust): Correct order of tests for
warning and indirect symbols.

bfd/ChangeLog
bfd/elf64-ppc.c

index 84ac6c0..7ec26b0 100644 (file)
@@ -1,5 +1,10 @@
 2016-12-03  Alan Modra  <amodra@gmail.com>
 
+       * elf64-ppc.c (add_symbol_adjust): Correct order of tests for
+       warning and indirect symbols.
+
+2016-12-03  Alan Modra  <amodra@gmail.com>
+
        * elf64-ppc.c (ppc64_elf_copy_indirect_symbol): Don't copy dynamic
        flags when direct symbol is versioned_hidden.
 
index bfdfc09..d7d6adb 100644 (file)
@@ -5063,12 +5063,12 @@ add_symbol_adjust (struct ppc_link_hash_entry *eh, struct bfd_link_info *info)
   struct ppc_link_hash_table *htab;
   struct ppc_link_hash_entry *fdh;
 
-  if (eh->elf.root.type == bfd_link_hash_indirect)
-    return TRUE;
-
   if (eh->elf.root.type == bfd_link_hash_warning)
     eh = (struct ppc_link_hash_entry *) eh->elf.root.u.i.link;
 
+  if (eh->elf.root.type == bfd_link_hash_indirect)
+    return TRUE;
+
   if (eh->elf.root.root.string[0] != '.')
     abort ();