diff options
author | Danny Smith <dannysmith@users.sourceforge.net> | 2008-07-31 07:27:52 +0000 |
---|---|---|
committer | Danny Smith <dannysmith@users.sourceforge.net> | 2008-07-31 07:27:52 +0000 |
commit | 49314f8728c7d2fcfcaa20771bf7a453901db081 (patch) | |
tree | acd741aa05e90c67eb177b03badd9caa8135ae47 /ld/pe-dll.c | |
parent | 2f9300efcdb2abb98ac68fbeafed47ac956c0d26 (diff) | |
download | gdb-49314f8728c7d2fcfcaa20771bf7a453901db081.zip gdb-49314f8728c7d2fcfcaa20771bf7a453901db081.tar.gz gdb-49314f8728c7d2fcfcaa20771bf7a453901db081.tar.bz2 |
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.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/ld/pe-dll.c b/ld/pe-dll.c index 692f80f..c6c656a 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 |