summaryrefslogtreecommitdiff
path: root/ld/plugin.c
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2011-02-26 04:38:34 +0000
committerH.J. Lu <hjl.tools@gmail.com>2011-02-26 04:38:34 +0000
commitd0a343a33beb0e9fa0fd3b2680ee0588ddf153c9 (patch)
treeede56c0a9f35b1466a839f5b248601f704046fbc /ld/plugin.c
parent6618aa1f40fe16cb52030c9018943133dca06551 (diff)
downloadbinutils-redhat-d0a343a33beb0e9fa0fd3b2680ee0588ddf153c9.tar.gz
Add entry_symbol chain into non_ironly_hash.
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.
Diffstat (limited to 'ld/plugin.c')
-rw-r--r--ld/plugin.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/ld/plugin.c b/ld/plugin.c
index 6e3f923245..7ac2cb85ee 100644
--- a/ld/plugin.c
+++ b/ld/plugin.c
@@ -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);
}
}