From 6de00a78235f512af73af5ea4b4f0e60e8b45ca0 Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Wed, 14 Apr 2004 09:50:07 +0000 Subject: [PATCH] * elf32-sparc.c (elf32_sparc_relocate_section): Don't abort when statically linking PIC code. * elf64-sparc.c (sparc64_elf_relocate_section): Likewise. --- bfd/ChangeLog | 6 ++++++ bfd/elf32-sparc.c | 5 +---- bfd/elf64-sparc.c | 11 +++-------- 3 files changed, 10 insertions(+), 12 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index c453657ab86..7aff007df50 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2004-04-14 Alan Modra + + * elf32-sparc.c (elf32_sparc_relocate_section): Don't abort + when statically linking PIC code. + * elf64-sparc.c (sparc64_elf_relocate_section): Likewise. + 2004-04-11 Thiemo Seufer * config.bfd: Remove mips*-*-mach3* and mips*-dec-mach3* targets. diff --git a/bfd/elf32-sparc.c b/bfd/elf32-sparc.c index 3016652678b..0f94f5f31bb 100644 --- a/bfd/elf32-sparc.c +++ b/bfd/elf32-sparc.c @@ -2323,7 +2323,7 @@ elf32_sparc_relocate_section (output_bfd, info, input_bfd, input_section, if (h == NULL) break; - if (h->plt.offset == (bfd_vma) -1) + if (h->plt.offset == (bfd_vma) -1 || htab->splt == NULL) { /* We didn't make a PLT entry for this symbol. This happens when statically linking PIC code, or when @@ -2331,9 +2331,6 @@ elf32_sparc_relocate_section (output_bfd, info, input_bfd, input_section, break; } - if (htab->splt == NULL) - abort (); - relocation = (htab->splt->output_section->vma + htab->splt->output_offset + h->plt.offset); diff --git a/bfd/elf64-sparc.c b/bfd/elf64-sparc.c index dd3e4962e2f..0b65380aae6 100644 --- a/bfd/elf64-sparc.c +++ b/bfd/elf64-sparc.c @@ -2027,7 +2027,8 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, else got_base = elf_hash_table (info)->hgot->root.u.def.value; - sgot = splt = sreloc = NULL; + sgot = sreloc = NULL; + splt = bfd_get_section_by_name (dynobj, ".plt"); rel = relocs; relend = relocs + NUM_SHDR_ENTRIES (& elf_section_data (input_section)->rel_hdr); @@ -2409,7 +2410,7 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, procedure linkage table. */ BFD_ASSERT (h != NULL); - if (h->plt.offset == (bfd_vma) -1) + if (h->plt.offset == (bfd_vma) -1 || splt == NULL) { /* We didn't make a PLT entry for this symbol. This happens when statically linking PIC code, or when @@ -2417,12 +2418,6 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, goto do_default; } - if (splt == NULL) - { - splt = bfd_get_section_by_name (dynobj, ".plt"); - BFD_ASSERT (splt != NULL); - } - relocation = (splt->output_section->vma + splt->output_offset + sparc64_elf_plt_entry_offset (h->plt.offset)); -- 2.30.2