From: Kaz Kojima Date: Sat, 31 Dec 2005 16:23:13 +0000 (+0000) Subject: * elf32-sh.c (sh_elf_relocate_section): Don't reset relocation X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f50ad433e80064538325e82938f11d1bf0c0828c;p=binutils-gdb.git * elf32-sh.c (sh_elf_relocate_section): Don't reset relocation for R_SH_REL32 in shared objects if the symbol is locally called. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 731ad0487e7..dc6be124f7f 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2005-12-31 Valeriy E. Ushakov + Kaz Kojima + + * elf32-sh.c (sh_elf_relocate_section): Don't reset relocation + for R_SH_REL32 in shared objects if the symbol is locally called. + 2005-12-31 Alan Modra * elf64-ppc.c (ppc64_elf_relocate_section): Adjust relocs against diff --git a/bfd/elf32-sh.c b/bfd/elf32-sh.c index 4d1e280881f..4d07414cd1b 100644 --- a/bfd/elf32-sh.c +++ b/bfd/elf32-sh.c @@ -4693,7 +4693,8 @@ sh_elf_relocate_section (bfd *output_bfd, struct bfd_link_info *info, || !h->def_regular) && ((r_type == R_SH_DIR32 && !h->forced_local) - || r_type == R_SH_REL32) + || (r_type == R_SH_REL32 + && !SYMBOL_CALLS_LOCAL (info, h))) && ((input_section->flags & SEC_ALLOC) != 0 /* DWARF will emit R_SH_DIR32 relocations in its sections against symbols defined externally