From bb651f451ea0a60edf5d381ec563fbec5b9bc7ad Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Thu, 4 Oct 2001 16:09:03 +0000 Subject: * elf32-mips.c (_bfd_mips_elf_copy_indirect_symbol): Bail out after copying flags if this is a weakdef. --- bfd/elf32-mips.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'bfd/elf32-mips.c') diff --git a/bfd/elf32-mips.c b/bfd/elf32-mips.c index fd79bbaec62..6f39d9f2b75 100644 --- a/bfd/elf32-mips.c +++ b/bfd/elf32-mips.c @@ -8074,7 +8074,8 @@ _bfd_mips_elf_gc_sweep_hook (abfd, info, sec, relocs) /* Copy data from a MIPS ELF indirect symbol to its direct symbol, hiding the old indirect symbol. Process additional relocation - information. */ + information. Also called for weakdefs, in which case we just let + _bfd_elf_link_hach_copy_indirect copy the flags for us. */ static void _bfd_mips_elf_copy_indirect_symbol (dir, ind) @@ -8084,6 +8085,9 @@ _bfd_mips_elf_copy_indirect_symbol (dir, ind) _bfd_elf_link_hash_copy_indirect (dir, ind); + if (dir == ind->weakdef) + return; + dirmips = (struct mips_elf_link_hash_entry *) dir; indmips = (struct mips_elf_link_hash_entry *) ind; dirmips->possibly_dynamic_relocs += indmips->possibly_dynamic_relocs; -- cgit v1.2.1