summaryrefslogtreecommitdiff
path: root/bfd/elf.c
diff options
context:
space:
mode:
authorDoug Kwan <dougkwan@google.com>2012-05-08 17:18:16 +0000
committerDoug Kwan <dougkwan@google.com>2012-05-08 17:18:16 +0000
commit812beecb47cb77ed4984659840ac74e1c51fc908 (patch)
tree6a55e6f4f5ba45916d0fcdd05773237443911440 /bfd/elf.c
parent45a855816faeb72013072d9eb7ee152ed856756b (diff)
downloadbinutils-redhat-812beecb47cb77ed4984659840ac74e1c51fc908.tar.gz
2012-05-08 Ben Cheng <bccheng@google.com>
* bfd/elf.c: Preserve the original p_align and p_flags if they are valid.
Diffstat (limited to 'bfd/elf.c')
-rw-r--r--bfd/elf.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/bfd/elf.c b/bfd/elf.c
index d040d14700..9481c0e1d5 100644
--- a/bfd/elf.c
+++ b/bfd/elf.c
@@ -4931,8 +4931,14 @@ assign_file_positions_for_non_load_sections (bfd *abfd,
else
abort ();
p->p_memsz = p->p_filesz;
- p->p_align = 1;
- p->p_flags = (lp->p_flags & ~PF_W);
+ /* Preserve the alignment and flags if they are valid. The gold
+ linker generates RW/4 for the PT_GNU_RELRO section. It is better
+ for objcopy/strip to honor these attributes otherwise gdb will
+ choke when using separate debug files. */
+ if (!m->p_align_valid)
+ p->p_align = 1;
+ if (!m->p_flags_valid)
+ p->p_flags = (lp->p_flags & ~PF_W);
}
else
{