summaryrefslogtreecommitdiff
path: root/bfd
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2009-07-22 23:55:54 +0000
committerH.J. Lu <hjl.tools@gmail.com>2009-07-22 23:55:54 +0000
commit5f35ea9c04b9a4da4649c3178ee81bb1ab0ccae7 (patch)
treeb6a470a784b2fe26a0f517b5ecc950b6df84c2e3 /bfd
parentb63cc625a128b6eba0f66330d16db767a6f56038 (diff)
downloadbinutils-gdb-5f35ea9c04b9a4da4649c3178ee81bb1ab0ccae7.tar.gz
2009-07-22 H.J. Lu <hongjiu.lu@intel.com>
* elflink.c (elf_link_output_extsym): Revert the last change.
Diffstat (limited to 'bfd')
-rw-r--r--bfd/ChangeLog4
-rw-r--r--bfd/elflink.c5
2 files changed, 6 insertions, 3 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog
index 35e90b35967..7987bbc927b 100644
--- a/bfd/ChangeLog
+++ b/bfd/ChangeLog
@@ -1,5 +1,9 @@
2009-07-22 H.J. Lu <hongjiu.lu@intel.com>
+ * elflink.c (elf_link_output_extsym): Revert the last change.
+
+2009-07-22 H.J. Lu <hongjiu.lu@intel.com>
+
PR ld/10433
* elflink.c (elf_link_output_extsym): Special case ifunc syms
when ref_regular, not def_regular.
diff --git a/bfd/elflink.c b/bfd/elflink.c
index 2af1af578ac..f9b577c7738 100644
--- a/bfd/elflink.c
+++ b/bfd/elflink.c
@@ -8660,10 +8660,9 @@ elf_link_output_extsym (struct elf_link_hash_entry *h, void *data)
and also to finish up anything that needs to be done for this
symbol. FIXME: Not calling elf_backend_finish_dynamic_symbol for
forced local syms when non-shared is due to a historical quirk.
- STT_GNU_IFUNC symbol must go through PLT only if it is ever
- referenced. */
+ STT_GNU_IFUNC symbol must go through PLT. */
if ((h->type == STT_GNU_IFUNC
- && h->ref_regular
+ && h->def_regular
&& !finfo->info->relocatable)
|| ((h->dynindx != -1
|| h->forced_local)