* compress.c (bfd_cache_section_contents): New function.
	* bfd-in2.h: Regenerate.
binutils/
	* objdump.c (load_specific_debug_section): Use
	bfd_cache_section_contents.
This commit is contained in:
Alan Modra 2012-10-21 09:06:07 +00:00
parent 1e9d6fc263
commit 8a72cc6e7e
5 changed files with 37 additions and 7 deletions

View file

@ -1,3 +1,8 @@
2012-10-21 Alan Modra <amodra@gmail.com>
* compress.c (bfd_cache_section_contents): New function.
* bfd-in2.h: Regenerate.
2012-10-21 Hans-Peter Nilsson <hp@bitrange.com>
* linker.c (_bfd_generic_link_output_symbols): Handle a

View file

@ -6709,6 +6709,9 @@ bfd_boolean bfd_compress_section_contents
bfd_boolean bfd_get_full_section_contents
(bfd *abfd, asection *section, bfd_byte **ptr);
void bfd_cache_section_contents
(asection *sec, void *contents);
bfd_boolean bfd_is_section_compressed
(bfd *abfd, asection *section);

View file

@ -253,6 +253,29 @@ bfd_get_full_section_contents (bfd *abfd, sec_ptr sec, bfd_byte **ptr)
}
}
/*
FUNCTION
bfd_cache_section_contents
SYNOPSIS
void bfd_cache_section_contents
(asection *sec, void *contents);
DESCRIPTION
Stash @var(contents) so any following reads of @var(sec) do
not need to decompress again.
*/
void
bfd_cache_section_contents (asection *sec, void *contents)
{
if (sec->compress_status == DECOMPRESS_SECTION_SIZED)
sec->compress_status = COMPRESS_SECTION_DONE;
sec->contents = contents;
sec->flags |= SEC_IN_MEMORY;
}
/*
FUNCTION
bfd_is_section_compressed

View file

@ -1,3 +1,8 @@
2012-10-21 Alan Modra <amodra@gmail.com>
* objdump.c (load_specific_debug_section): Use
bfd_cache_section_contents.
2012-10-18 Kai Tietz <ktietz@redhat.com>
* objdump.c (dump_bfd): Call dump headers after

View file

@ -2272,13 +2272,7 @@ load_specific_debug_section (enum dwarf_section_display_enum debug,
if (is_relocatable && debug_displays [debug].relocate)
{
/* We want to relocate the data we've already read (and
decompressed), so we store a pointer to the data in
the bfd_section, and tell it that the contents are
already in memory. */
sec->contents = section->start;
sec->flags |= SEC_IN_MEMORY;
sec->size = section->size;
bfd_cache_section_contents (sec, section->start);
ret = bfd_simple_get_relocated_section_contents (abfd,
sec,