From 8af139b3f9d848a998f4b41ffdfe8b3723b39412 Mon Sep 17 00:00:00 2001 From: Eric Botcazou Date: Wed, 5 Jan 2005 15:24:56 +0000 Subject: [PATCH] * elf64-sparc.c (sparc64_elf_relocate_section): Ignore overflows from STABS debugging sections again. --- bfd/ChangeLog | 5 +++++ bfd/elf64-sparc.c | 10 +++++++--- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 3649cf8df32..831b9e1e557 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2005-01-05 Eric Botcazou + + * elf64-sparc.c (sparc64_elf_relocate_section): Ignore overflows + from STABS debugging sections again. + 2005-01-05 Fred Fish * dwarf2.c (struct dwarf2_debug): Add info_ptr_unit member. diff --git a/bfd/elf64-sparc.c b/bfd/elf64-sparc.c index 01b80cda4d5..6ffad929a70 100644 --- a/bfd/elf64-sparc.c +++ b/bfd/elf64-sparc.c @@ -2633,10 +2633,14 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, /* The Solaris native linker silently disregards overflows. We don't, but this breaks stabs debugging info, whose relocations are only 32-bits wide. Ignore - overflows for discarded entries. */ + overflows in this case and also for discarded entries. */ if ((r_type == R_SPARC_32 || r_type == R_SPARC_DISP32) - && _bfd_elf_section_offset (output_bfd, info, input_section, - rel->r_offset) == (bfd_vma) -1) + && (((input_section->flags & SEC_DEBUGGING) != 0 + && strcmp (bfd_section_name (input_bfd, input_section), + ".stab") == 0) + || _bfd_elf_section_offset (output_bfd, info, + input_section, + rel->r_offset) == (bfd_vma)-1)) break; if (h != NULL) -- 2.30.2