From: H.J. Lu Date: Tue, 10 Jul 2007 13:49:04 +0000 (+0000) Subject: 2007-07-10 H.J. Lu X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=329b43c490f3fa2573f65f3b1a7e717d4f1a43c3;p=binutils-gdb.git 2007-07-10 H.J. Lu PR binutils/4756 * simple.c (bfd_simple_get_relocated_section_content): Don't apply relocation on executable and shared library. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 104e4255888..267213edd6c 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2007-07-10 H.J. Lu + + PR binutils/4756 + * simple.c (bfd_simple_get_relocated_section_content): Don't + apply relocation on executable and shared library. + 2007-07-10 Nathan Sidwell * elf32-ppc.c (ppc_elf_adjust_dynamic_symbol): Don't eliminate diff --git a/bfd/simple.c b/bfd/simple.c index 452486834ab..1b92a05791c 100644 --- a/bfd/simple.c +++ b/bfd/simple.c @@ -162,7 +162,10 @@ bfd_simple_get_relocated_section_contents (bfd *abfd, int storage_needed; void *saved_offsets; - if (! (sec->flags & SEC_RELOC)) + /* Don't apply relocation on executable and shared library. See + PR 4756. */ + if ((abfd->flags & (HAS_RELOC | EXEC_P | DYNAMIC)) != HAS_RELOC + || ! (sec->flags & SEC_RELOC)) { bfd_size_type amt = sec->rawsize > sec->size ? sec->rawsize : sec->size; bfd_size_type size = sec->rawsize ? sec->rawsize : sec->size;