summaryrefslogtreecommitdiff
path: root/ld/pe-dll.c
diff options
context:
space:
mode:
authorDanny Smith <dannysmith@users.sourceforge.net>2008-07-31 07:27:52 +0000
committerDanny Smith <dannysmith@users.sourceforge.net>2008-07-31 07:27:52 +0000
commitd6967fb10aeaec960a7778db1f94fbf218a2cd7b (patch)
treeea9cd32bff99caf6eb8061574b28dbee42dc6a3e /ld/pe-dll.c
parent9c7af39e804495cf71b3c83f1604107644c10f47 (diff)
downloadbinutils-redhat-d6967fb10aeaec960a7778db1f94fbf218a2cd7b.tar.gz
2008-07-31 Takashi Ono <t_ono@hkfreak.net>
* pe-dll.c (generate_relocs): Don't generate relocs for undefined weak symbols.
Diffstat (limited to 'ld/pe-dll.c')
-rw-r--r--ld/pe-dll.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/ld/pe-dll.c b/ld/pe-dll.c
index 692f80fdbe..c6c656a230 100644
--- a/ld/pe-dll.c
+++ b/ld/pe-dll.c
@@ -1256,6 +1256,16 @@ generate_reloc (bfd *abfd, struct bfd_link_info *info)
bfd_vma sym_vma;
struct bfd_symbol *sym = *relocs[i]->sym_ptr_ptr;
+ /* Don't create relocs for undefined weak symbols. */
+ if (sym->flags == BSF_WEAK)
+ {
+ struct bfd_link_hash_entry *blhe
+ = bfd_link_hash_lookup (info->hash, sym->name,
+ FALSE, FALSE, FALSE);
+ if (!blhe || blhe->type != bfd_link_hash_defined)
+ continue;
+ }
+
sym_vma = (relocs[i]->addend
+ sym->value
+ sym->section->vma