diff options
Diffstat (limited to 'bfd/elflink.c')
-rw-r--r-- | bfd/elflink.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/bfd/elflink.c b/bfd/elflink.c index de1939ac7c8..69a7c6945ce 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -881,9 +881,11 @@ _bfd_elf_merge_symbol (bfd *abfd, return FALSE; *sym_hash = h; + bed = get_elf_backend_data (abfd); + /* This code is for coping with dynamic objects, and is only useful if we are doing an ELF link. */ - if (info->output_bfd->xvec != abfd->xvec) + if (!(*bed->relocs_compatible) (abfd->xvec, info->output_bfd->xvec)) return TRUE; /* For merging, we only care about real symbols. */ @@ -970,7 +972,6 @@ _bfd_elf_merge_symbol (bfd *abfd, && h->root.type != bfd_link_hash_undefweak && h->root.type != bfd_link_hash_common); - bed = get_elf_backend_data (abfd); /* When we try to create a default indirect symbol from the dynamic definition with the default version, we skip it if its type and the type of existing regular definition mismatch. We only do it |