diff options
author | Alan Modra <amodra@gmail.com> | 2014-02-08 12:26:53 +1030 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2014-02-09 23:25:14 +1030 |
commit | 53291d1f1601d6958248dcfb755af470521c186a (patch) | |
tree | 6c7d8b35b6792238cc852ff9e3866f154c77f8e2 /bfd/elflink.c | |
parent | f9e7e5d3e6b8715d702cf0d530e8ca6cd243cd8b (diff) | |
download | gdb-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.c | 11 |
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; |