diff options
author | Alan Modra <amodra@gmail.com> | 2015-07-25 16:38:42 +0930 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2015-07-25 20:41:04 +0930 |
commit | a496fbc8802f0a5719db6347a43cc869e03d83c9 (patch) | |
tree | 21bdd4f9bfe1bb57b0690d57ac485dd9bd189d71 /bfd/elf32-nios2.c | |
parent | ca3084f54b62ce06c6e70a6e1daafeb5e3317c12 (diff) | |
download | gdb-a496fbc8802f0a5719db6347a43cc869e03d83c9.zip gdb-a496fbc8802f0a5719db6347a43cc869e03d83c9.tar.gz gdb-a496fbc8802f0a5719db6347a43cc869e03d83c9.tar.bz2 |
Fix broken -Bsymbolic-functions
For selected targets. The testcase reveals a number of targets that
still need fixing.
bfd/
* elf32-arm.c (elf32_arm_final_link_relocate): Use SYMBOLIC_BIND to
check if a symbol should be bound symbolically.
* elf32-hppa.c (elf32_hppa_check_relocs,
elf32_hppa_adjust_dynamic_symbol, elf32_hppa_relocate_section,
elf32_hppa_finish_dynamic_symbol): Likewise.
* elf32-m68k.c (elf_m68k_check_relocs,
elf_m68k_relocate_section): Likewise.
* elf32-nios2.c (nios2_elf32_relocate_section,
nios2_elf32_check_relocs, allocate_dynrelocs): Likewise.
* elf32-tic6x.c (elf32_tic6x_finish_dynamic_symbol,
elf32_tic6x_relocate_section): Likewise.
ld/testsuite/
* ld-elf/symbolic-func.s,
* ld-elf/symbolic-func.r: New test.
* ld-elf/elf.exp: Run it.
Diffstat (limited to 'bfd/elf32-nios2.c')
-rw-r--r-- | bfd/elf32-nios2.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/bfd/elf32-nios2.c b/bfd/elf32-nios2.c index e5b7763..a5ab54f 100644 --- a/bfd/elf32-nios2.c +++ b/bfd/elf32-nios2.c @@ -4398,7 +4398,7 @@ nios2_elf32_relocate_section (bfd *output_bfd, else if (h != NULL && h->dynindx != -1 && (!info->shared - || !info->symbolic + || !SYMBOLIC_BIND (info, h) || !h->def_regular)) { outrel.r_info = ELF32_R_INFO (h->dynindx, r_type); @@ -4909,7 +4909,7 @@ nios2_elf32_check_relocs (bfd *abfd, struct bfd_link_info *info, && (sec->flags & SEC_ALLOC) != 0 && (r_type == R_NIOS2_BFD_RELOC_32 || (h != NULL && ! h->needs_plt - && (! info->symbolic || ! h->def_regular)))) + && (! SYMBOLIC_BIND (info, h) || ! h->def_regular)))) { struct elf32_nios2_dyn_relocs *p; struct elf32_nios2_dyn_relocs **head; @@ -5752,7 +5752,7 @@ allocate_dynrelocs (struct elf_link_hash_entry *h, PTR inf) if (info->shared) { if (h->def_regular - && (h->forced_local || info->symbolic)) + && (h->forced_local || SYMBOLIC_BIND (info, h))) { struct elf32_nios2_dyn_relocs **pp; |