Add entry_symbol chain into non_ironly_hash.
authorH.J. Lu <hjl.tools@gmail.com>
Sat, 26 Feb 2011 04:38:34 +0000 (04:38 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Sat, 26 Feb 2011 04:38:34 +0000 (04:38 +0000)
2011-02-24  H.J. Lu  <hongjiu.lu@intel.com>

PR ld/12507
* plugin.c (get_symbols): Don't check entry symbol here.
(init_non_ironly_hash): Add entry_symbol chain into
non_ironly_hash.

ld/ChangeLog
ld/plugin.c

index c6722094e40173562e50cf41ab02b5ad0056698f..aa459a05bf656dd4bd5795af427f2ced59db5e51 100644 (file)
@@ -1,3 +1,10 @@
+2011-02-24  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR ld/12507
+       * plugin.c (get_symbols): Don't check entry symbol here.
+       (init_non_ironly_hash): Add entry_symbol chain into
+       non_ironly_hash.
+
 2011-02-24  H.J. Lu  <hongjiu.lu@intel.com>
 
        PR ld/12507
index 6e3f923245345ef346daefca05e303432a318089..7ac2cb85ee0ac58843fbe9a0c45d56a6389a3847 100644 (file)
@@ -495,8 +495,7 @@ get_symbols (const void *handle, int nsyms, struct ld_plugin_symbol *syms)
         symbol is externally visible.  */
       ironly = (!is_visible_from_outside (&syms[n], owner_sec, blhe)
                && !bfd_hash_lookup (non_ironly_hash, syms[n].name,
-                                    FALSE, FALSE)
-               && strcmp (syms[n].name, entry_symbol.name) != 0);
+                                    FALSE, FALSE));
 
       /* If it was originally undefined or common, then it has been
         resolved; determine how.  */
@@ -845,6 +844,8 @@ plugin_call_cleanup (void)
 static void
 init_non_ironly_hash (void)
 {
+  struct bfd_sym_chain *sym;
+
   if (non_ironly_hash == NULL)
     {
       non_ironly_hash =
@@ -854,6 +855,12 @@ init_non_ironly_hash (void)
                                  sizeof (struct bfd_hash_entry),
                                  61))
        einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
+
+      for (sym = &entry_symbol; sym != NULL; sym = sym->next)
+       if (sym->name
+           && !bfd_hash_lookup (non_ironly_hash, sym->name, TRUE, TRUE))
+         einfo (_("%P%X: hash table failure adding symbol %s\n"),
+                sym->name);
     }
 }