From e4daa1cec770d3f7fa439c2e70edf17cc8989286 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Tue, 10 Jul 2007 13:49:04 +0000 Subject: [PATCH] 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. --- bfd/ChangeLog | 6 ++++++ bfd/simple.c | 5 ++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 104e42558..267213edd 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 452486834..1b92a0579 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; -- 2.11.4.GIT