From d4e57b87a3d5879917c30e33b14760fd76ff7b38 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Tue, 29 Dec 2020 10:41:51 -0800 Subject: bfin: Check bfd_link_hash_indirect Add bfd_link_hash_indirect check to check_relocs. This fixed: FAIL: ld-elf/pr26979a FAIL: ld-elf/pr26979b FAIL: Symbol export class test (final shared object) * elf32-bfin.c (bfin_check_relocs): Check bfd_link_hash_indirect. (bfinfdpic_check_relocs): Likewise. --- bfd/ChangeLog | 5 +++++ bfd/elf32-bfin.c | 10 +++++++++- 2 files changed, 14 insertions(+), 1 deletion(-) (limited to 'bfd') diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 06d6e39..3a219c7 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2021-01-06 H.J. Lu + + * elf32-bfin.c (bfin_check_relocs): Check bfd_link_hash_indirect. + (bfinfdpic_check_relocs): Likewise. + 2021-01-06 Alan Modra * elf32-score.c (s3_bfd_score_info_to_howto): Report an error diff --git a/bfd/elf32-bfin.c b/bfd/elf32-bfin.c index 0d8050f..7c926b8 100644 --- a/bfd/elf32-bfin.c +++ b/bfd/elf32-bfin.c @@ -1197,6 +1197,9 @@ bfin_check_relocs (bfd * abfd, else { h = sym_hashes[r_symndx - symtab_hdr->sh_info]; + while (h->root.type == bfd_link_hash_indirect + || h->root.type == bfd_link_hash_warning) + h = (struct elf_link_hash_entry *)h->root.u.i.link; } switch (ELF32_R_TYPE (rel->r_info)) @@ -4523,7 +4526,12 @@ bfinfdpic_check_relocs (bfd *abfd, struct bfd_link_info *info, if (r_symndx < symtab_hdr->sh_info) h = NULL; else - h = sym_hashes[r_symndx - symtab_hdr->sh_info]; + { + h = sym_hashes[r_symndx - symtab_hdr->sh_info]; + while (h->root.type == bfd_link_hash_indirect + || h->root.type == bfd_link_hash_warning) + h = (struct elf_link_hash_entry *) h->root.u.i.link; + } switch (ELF32_R_TYPE (rel->r_info)) { -- cgit v1.1