From 0d591ff7fb37443cbb15bc2b7f0dc192cc124094 Mon Sep 17 00:00:00 2001 From: Richard Sandiford Date: Wed, 9 Jul 2003 11:52:52 +0000 Subject: [PATCH] * elfxx-mips.c (mips_elf_create_dynamic_relocation): Fix handling of relocations whose offset is -2. --- bfd/ChangeLog | 5 +++++ bfd/elfxx-mips.c | 12 ++++++++++-- 2 files changed, 15 insertions(+), 2 deletions(-) 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 -- 2.30.2