aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2022-08-20 17:36:41 +0930
committerAlan Modra <amodra@gmail.com>2022-08-21 07:54:27 +0930
commit77491337229beca6f071282ac4283c46262854ec (patch)
tree44b033bad4208872657b2dfaad1e697387ea4c51
parent0ade20c5688d328ea91d4822384af46d7f899cb1 (diff)
downloadbinutils-77491337229beca6f071282ac4283c46262854ec.zip
binutils-77491337229beca6f071282ac4283c46262854ec.tar.gz
binutils-77491337229beca6f071282ac4283c46262854ec.tar.bz2
symbols for bfd_simple_get_relocated_section_contents
If symbols are provided by the caller of this function they are passed on to bfd_get_relocated_section_contents. No surprises there. It gets a little weird if they are not provided. In that case they are read from the bfd by _bfd_generic_link_add_symbols, and global symbols are added to the generic linker hash table. Global symbols are not added to the linker hash table if symbols *are* provided. Now the linker hash table symbols are not used by the generic bfd_get_relocated_section_conents, and also not by most target versions when called from bfd_simple_get_relocated_section_contents except for symbols like "_gp". So it mostly doesn't matter whether symbols are in the linker hash table, but it's odd that there is a difference. We could always add them, but I'm inclined to think that is unnecessary work so this patch always leaves them out. Also, symbols are canonicalized and written into a malloc'd buffer. The buffer isn't freed, see commit 8e16317ca5eb. I don't know whether that matters any more, but in any case I can't see why we need another copy of the symbols when _bfd_generic_link_read_symbols has already cached symbols. * simple.c (bfd_simple_get_relocated_section_contents): If not provided, read symbols via bfd_generic_link_read_symbols. Do not create another copy of symbols. Tidy failure exits. Minor tidy of bfd_get_relocated_section_contents and bfd_get_full_section_contents arguments.
-rw-r--r--bfd/simple.c42
1 files changed, 15 insertions, 27 deletions
diff --git a/bfd/simple.c b/bfd/simple.c
index 6ccafd2..67e326d 100644
--- a/bfd/simple.c
+++ b/bfd/simple.c
@@ -23,6 +23,7 @@
#include "bfd.h"
#include "libbfd.h"
#include "bfdlink.h"
+#include "genlink.h"
static void
simple_dummy_add_to_set (struct bfd_link_info * info ATTRIBUTE_UNUSED,
@@ -209,7 +210,6 @@ bfd_simple_get_relocated_section_contents (bfd *abfd,
struct bfd_link_order link_order;
struct bfd_link_callbacks callbacks;
bfd_byte *contents, *data;
- int storage_needed;
struct saved_offsets saved_offsets;
bfd *link_next;
@@ -218,10 +218,9 @@ bfd_simple_get_relocated_section_contents (bfd *abfd,
if ((abfd->flags & (HAS_RELOC | EXEC_P | DYNAMIC)) != HAS_RELOC
|| ! (sec->flags & SEC_RELOC))
{
- contents = outbuf;
- if (!bfd_get_full_section_contents (abfd, sec, &contents))
+ if (!bfd_get_full_section_contents (abfd, sec, &outbuf))
return NULL;
- return contents;
+ return outbuf;
}
/* In order to use bfd_get_relocated_section_contents, we need
@@ -259,16 +258,13 @@ bfd_simple_get_relocated_section_contents (bfd *abfd,
link_order.u.indirect.section = sec;
data = NULL;
+ contents = NULL;
if (outbuf == NULL)
{
bfd_size_type amt = sec->rawsize > sec->size ? sec->rawsize : sec->size;
data = (bfd_byte *) bfd_malloc (amt);
if (data == NULL)
- {
- _bfd_generic_link_hash_table_free (abfd);
- abfd->link.next = link_next;
- return NULL;
- }
+ goto out1;
outbuf = data;
}
@@ -276,37 +272,29 @@ bfd_simple_get_relocated_section_contents (bfd *abfd,
saved_offsets.sections = malloc (sizeof (*saved_offsets.sections)
* saved_offsets.section_count);
if (saved_offsets.sections == NULL)
- {
- free (data);
- _bfd_generic_link_hash_table_free (abfd);
- abfd->link.next = link_next;
- return NULL;
- }
+ goto out2;
bfd_map_over_sections (abfd, simple_save_output_info, &saved_offsets);
if (symbol_table == NULL)
{
- _bfd_generic_link_add_symbols (abfd, &link_info);
-
- storage_needed = bfd_get_symtab_upper_bound (abfd);
- symbol_table = (asymbol **) bfd_malloc (storage_needed);
- bfd_canonicalize_symtab (abfd, symbol_table);
+ if (!bfd_generic_link_read_symbols (abfd))
+ goto out3;
+ symbol_table = _bfd_generic_link_get_symbols (abfd);
}
- else
- storage_needed = 0;
contents = bfd_get_relocated_section_contents (abfd,
&link_info,
&link_order,
outbuf,
- 0,
+ false,
symbol_table);
- if (contents == NULL)
- free (data);
-
+ out3:
bfd_map_over_sections (abfd, simple_restore_output_info, &saved_offsets);
free (saved_offsets.sections);
-
+ out2:
+ if (contents == NULL)
+ free (data);
+ out1:
_bfd_generic_link_hash_table_free (abfd);
abfd->link.next = link_next;
return contents;