aboutsummaryrefslogtreecommitdiff
path: root/bfd/elflink.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2014-02-08 12:26:53 +1030
committerAlan Modra <amodra@gmail.com>2014-02-09 23:25:14 +1030
commit53291d1f1601d6958248dcfb755af470521c186a (patch)
tree6c7d8b35b6792238cc852ff9e3866f154c77f8e2 /bfd/elflink.c
parentf9e7e5d3e6b8715d702cf0d530e8ca6cd243cd8b (diff)
downloadgdb-53291d1f1601d6958248dcfb755af470521c186a.zip
gdb-53291d1f1601d6958248dcfb755af470521c186a.tar.gz
gdb-53291d1f1601d6958248dcfb755af470521c186a.tar.bz2
powerpc relax_section and section contents cache
This patch provides a means for backend relax_section support to increase the size of a section without needing to reallocate section contents. This helps reduce memory usage when the added space does not need to be written in relax_section, as is the case for powerpc. Writing the stubs later means a few tweaks are needed in the powerpc relocate_section function, but also removes some code duplication since the extra ld -r relocs can be written there too. * elf-bfd.h (struct elf_backend_data): Add caches_rawsize. * elfxx-target.h (elf_backend_caches_rawsize): Define. (elfNN_bed): Init new field. * elflink.c (elf_link_input_bfd): Handle caches_rawsize. * elf32-ppc.c (shared_stub_entry): Zero addi offset. (ppc_elf_relax_section): Don't reallocate section here, write stubs, or write out relocs for ld -r here.. (ppc_elf_relocate_section): ..instead write stubs here, and use existing code to write out relocs for ld -r. Fix offset adjustment on reloc for little-endian. (elf_backend_caches_rawsize): Define.
Diffstat (limited to 'bfd/elflink.c')
-rw-r--r--bfd/elflink.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/bfd/elflink.c b/bfd/elflink.c
index 88967c8..af4f6bb 100644
--- a/bfd/elflink.c
+++ b/bfd/elflink.c
@@ -9549,7 +9549,16 @@ elf_link_input_bfd (struct elf_final_link_info *flinfo, bfd *input_bfd)
file, so the contents field will not have been set by any of
the routines which work on output files. */
if (elf_section_data (o)->this_hdr.contents != NULL)
- contents = elf_section_data (o)->this_hdr.contents;
+ {
+ contents = elf_section_data (o)->this_hdr.contents;
+ if (bed->caches_rawsize
+ && o->rawsize != 0
+ && o->rawsize < o->size)
+ {
+ memcpy (flinfo->contents, contents, o->rawsize);
+ contents = flinfo->contents;
+ }
+ }
else
{
contents = flinfo->contents;