aboutsummaryrefslogtreecommitdiff
path: root/bfd/elf32-i386.c
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2016-04-20 05:34:02 -0700
committerH.J. Lu <hjl.tools@gmail.com>2016-04-20 05:34:15 -0700
commit466ee2af4a927fc6aaaaa62b0abd3b0cff9bcef7 (patch)
treefd1b6f03bb7bbee3d8be51584755205fb7f71af2 /bfd/elf32-i386.c
parentd968975277ba280372002800c6c25bb1b29f496e (diff)
downloadbinutils-466ee2af4a927fc6aaaaa62b0abd3b0cff9bcef7.zip
binutils-466ee2af4a927fc6aaaaa62b0abd3b0cff9bcef7.tar.gz
binutils-466ee2af4a927fc6aaaaa62b0abd3b0cff9bcef7.tar.bz2
Call _bfd_elf_create_ifunc_sections only for ifunc
Since x86 check_relocs is called after opening all input files, we need to call _bfd_elf_create_ifunc_sections only for STT_GNU_IFUNC symbols. * elf32-i386.c (elf_i386_check_relocs): Call _bfd_elf_create_ifunc_sections only for STT_GNU_IFUNC symbol. * elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
Diffstat (limited to 'bfd/elf32-i386.c')
-rw-r--r--bfd/elf32-i386.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/bfd/elf32-i386.c b/bfd/elf32-i386.c
index 470fcd1..0a2ac9d 100644
--- a/bfd/elf32-i386.c
+++ b/bfd/elf32-i386.c
@@ -1603,10 +1603,6 @@ elf_i386_check_relocs (bfd *abfd,
eh = (struct elf_i386_link_hash_entry *) h;
if (h != NULL)
{
- /* Create the ifunc sections for static executables. If we
- never see an indirect function symbol nor we are building
- a static executable, those sections will be empty and
- won't appear in output. */
switch (r_type)
{
default:
@@ -1621,7 +1617,10 @@ elf_i386_check_relocs (bfd *abfd,
case R_386_GOT32X:
if (htab->elf.dynobj == NULL)
htab->elf.dynobj = abfd;
- if (!_bfd_elf_create_ifunc_sections (htab->elf.dynobj, info))
+ /* Create the ifunc sections for static executables. */
+ if (h->type == STT_GNU_IFUNC
+ && !_bfd_elf_create_ifunc_sections (htab->elf.dynobj,
+ info))
return FALSE;
break;
}