From: Richard Sandiford Date: Wed, 9 Jul 2003 11:52:52 +0000 (+0000) Subject: * elfxx-mips.c (mips_elf_create_dynamic_relocation): Fix handling X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0d591ff7fb37443cbb15bc2b7f0dc192cc124094;p=binutils-gdb.git * elfxx-mips.c (mips_elf_create_dynamic_relocation): Fix handling of relocations whose offset is -2. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 426c76ca983..c2029a0214e 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2003-07-09 Richard Sandiford + + * elfxx-mips.c (mips_elf_create_dynamic_relocation): Fix handling + of relocations whose offset is -2. + 2003-07-09 Richard Sandiford * bfd/elfxx-mips.c (mips_elf_create_dynamic_relocation): Treat diff --git a/bfd/elfxx-mips.c b/bfd/elfxx-mips.c index bef1c79b5e0..9ad54fc34c4 100644 --- a/bfd/elfxx-mips.c +++ b/bfd/elfxx-mips.c @@ -3875,9 +3875,17 @@ mips_elf_create_dynamic_relocation (output_bfd, info, rel, h, sec, } #endif - if (outrel[0].r_offset == (bfd_vma) -1 - || outrel[0].r_offset == (bfd_vma) -2) + if (outrel[0].r_offset == (bfd_vma) -1) + /* The relocation field has been deleted. */ skip = TRUE; + else if (outrel[0].r_offset == (bfd_vma) -2) + { + /* The relocation field has been converted into a relative value of + some sort. Functions like _bfd_elf_write_section_eh_frame expect + the field to be fully relocated, so add in the symbol's value. */ + skip = TRUE; + *addendp += symbol; + } /* If we've decided to skip this relocation, just output an empty record. Note that R_MIPS_NONE == 0, so that this call to memset