From: Marcus Shawcroft Date: Tue, 10 Mar 2015 13:16:28 +0000 (+0000) Subject: Factor stub creation code into _bfd_aarch64_create_stub_section. X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8e8b66cd484cbc9135d601149b4c8baf17adc9aa;p=thirdparty%2Fbinutils-gdb.git Factor stub creation code into _bfd_aarch64_create_stub_section. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 841e5a0720c..1a38e09a922 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,11 @@ 2015-03-04 Marcus Shawcroft + * elfnn-aarch64.c (_bfd_aarch64_create_or_find_stub_sec): Factor stub + creation code into... + (bfd_aarch64_create_stub_section): Define. + +2015-03-23 Marcus Shawcroft + * elfnn-aarch64.c (_bfd_aarch64_create_or_find_stub_sec): Rename from elf_aarch64_create_or_find_stub_sec. (_bfd_aarch64_add_stub_entry_in_group): Rename from diff --git a/bfd/elfnn-aarch64.c b/bfd/elfnn-aarch64.c index 9e58594f8d5..b7a3bbe24a0 100644 --- a/bfd/elfnn-aarch64.c +++ b/bfd/elfnn-aarch64.c @@ -2304,6 +2304,28 @@ elfNN_aarch64_get_stub_entry (const asection *input_section, } +/* Create a stub section. */ + +static asection * +_bfd_aarch64_create_stub_section (asection *section, + struct elf_aarch64_link_hash_table *htab) +{ + size_t namelen; + bfd_size_type len; + char *s_name; + + namelen = strlen (section->name); + len = namelen + sizeof (STUB_SUFFIX); + s_name = bfd_alloc (htab->stub_bfd, len); + if (s_name == NULL) + return NULL; + + memcpy (s_name, section->name, namelen); + memcpy (s_name + namelen, STUB_SUFFIX, sizeof (STUB_SUFFIX)); + return (*htab->add_stub_section) (s_name, section); +} + + /* Find or create a stub section in the stub group for an input section. */ @@ -2323,20 +2345,7 @@ _bfd_aarch64_create_or_find_stub_sec (asection *section, stub_sec = htab->stub_group[link_sec->id].stub_sec; if (stub_sec == NULL) { - size_t namelen; - bfd_size_type len; - char *s_name; - - namelen = strlen (link_sec->name); - len = namelen + sizeof (STUB_SUFFIX); - s_name = bfd_alloc (htab->stub_bfd, len); - if (s_name == NULL) - return NULL; - - memcpy (s_name, link_sec->name, namelen); - memcpy (s_name + namelen, STUB_SUFFIX, sizeof (STUB_SUFFIX)); - stub_sec = (*htab->add_stub_section) (s_name, link_sec); - + stub_sec = _bfd_aarch64_create_stub_section (link_sec, htab) if (stub_sec == NULL) return NULL; htab->stub_group[link_sec->id].stub_sec = stub_sec;