diff options
author | Alan Modra <amodra@gmail.com> | 2005-01-11 09:32:53 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2005-01-11 09:32:53 +0000 |
commit | 3eb128b2a5632a80460a8c22414e3541d1531d02 (patch) | |
tree | 13ad7265d567a369e3b24fbc35cda9c7a97d8cd0 /bfd/elf32-vax.c | |
parent | 264a1fe053aad624f8072e11e501f853b1a221a5 (diff) | |
download | gdb-3eb128b2a5632a80460a8c22414e3541d1531d02.zip gdb-3eb128b2a5632a80460a8c22414e3541d1531d02.tar.gz gdb-3eb128b2a5632a80460a8c22414e3541d1531d02.tar.bz2 |
* elf64-ppc.c (ppc64_elf_gc_sweep_hook): Follow indirect and warning
symbols.
* elf32-arm.c (elf32_arm_gc_sweep_hook): Likewise.
* elf32-cris.c (cris_elf_gc_sweep_hook): Likewise.
* elf32-hppa.c (elf32_hppa_gc_sweep_hook): Likewise.
* elf32-i386.c (elf_i386_gc_sweep_hook): Likewise.
* elf32-m32r.c (m32r_elf_gc_sweep_hook): Likewise.
* elf32-m68k.c (elf_m68k_gc_sweep_hook): Likewise.
* elf32-ppc.c (ppc_elf_gc_sweep_hook): Likewise.
* elf32-s390.c (elf_s390_gc_sweep_hook): Likewise.
* elf32-sh.c (sh_elf_gc_sweep_hook): Likewise.
* elf32-sparc.c (elf32_sparc_gc_sweep_hook): Likewise.
* elf32-vax.c (elf_vax_gc_sweep_hook): Likewise.
* elf32-xtensa.c (elf_xtensa_gc_sweep_hook): Likewise.
* elf64-s390.c (elf_s390_gc_sweep_hook): Likewise.
* elf64-x86-64.c (elf64_x86_64_gc_sweep_hook): Likewise.
Diffstat (limited to 'bfd/elf32-vax.c')
-rw-r--r-- | bfd/elf32-vax.c | 31 |
1 files changed, 15 insertions, 16 deletions
diff --git a/bfd/elf32-vax.c b/bfd/elf32-vax.c index 6d5493b..a98f96b 100644 --- a/bfd/elf32-vax.c +++ b/bfd/elf32-vax.c @@ -1,6 +1,6 @@ /* VAX series support for 32-bit ELF Copyright 1993, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, - 2004 Free Software Foundation, Inc. + 2004, 2005 Free Software Foundation, Inc. Contributed by Matt Thomas <matt@3am-software.com>. This file is part of BFD, the Binary File Descriptor library. @@ -904,18 +904,22 @@ elf_vax_gc_sweep_hook (abfd, info, sec, relocs) for (rel = relocs; rel < relend; rel++) { unsigned long r_symndx; - struct elf_link_hash_entry *h; + struct elf_link_hash_entry *h = NULL; + + r_symndx = ELF32_R_SYM (rel->r_info); + if (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)) { case R_VAX_GOT32: - r_symndx = ELF32_R_SYM (rel->r_info); - if (r_symndx >= symtab_hdr->sh_info) - { - h = sym_hashes[r_symndx - symtab_hdr->sh_info]; - if (h->got.refcount > 0) - --h->got.refcount; - } + if (h != NULL && h->got.refcount > 0) + --h->got.refcount; break; case R_VAX_PLT32: @@ -925,13 +929,8 @@ elf_vax_gc_sweep_hook (abfd, info, sec, relocs) case R_VAX_8: case R_VAX_16: case R_VAX_32: - r_symndx = ELF32_R_SYM (rel->r_info); - if (r_symndx >= symtab_hdr->sh_info) - { - h = sym_hashes[r_symndx - symtab_hdr->sh_info]; - if (h->plt.refcount > 0) - --h->plt.refcount; - } + if (h != NULL && h->plt.refcount > 0) + --h->plt.refcount; break; default: |