From: amodra Date: Wed, 31 Oct 2007 07:40:11 +0000 (+0000) Subject: * readelf.c (debug_apply_rela_addends): Clarify FIXME. X-Git-Tag: EOL_registry_mounts~1819 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=a987c16b0121d756d650726d9b38ef5cd86d6479;p=pf3gnuchains%2Fpf3gnuchains4x.git * readelf.c (debug_apply_rela_addends): Clarify FIXME. --- diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 2f50eff62e..abd9a96d87 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,7 @@ +2007-10-31 Alan Modra + + * readelf.c (debug_apply_rela_addends): Clarify FIXME. + 2007-10-29 Nick Clifton * readelf.c (is_32bit_abs_reloc): Add knowledge of reloc used by diff --git a/binutils/readelf.c b/binutils/readelf.c index 724e5f077d..9ae077935e 100644 --- a/binutils/readelf.c +++ b/binutils/readelf.c @@ -8242,14 +8242,13 @@ debug_apply_rela_addends (void *file, continue; } - if (is_32bit_pcrel_reloc (reloc_type)) - /* FIXME: Not sure how to apply a pc-rel reloc yet. - I think that it ought to be: - (rp->r_addend + sym->st_value) - rp->r_offset - but this breaks GAS CFI tests... */ - byte_put (loc, (rp->r_addend + sym->st_value) /*- rp->r_offset*/, reloc_size); - else - byte_put (loc, rp->r_addend + sym->st_value, reloc_size); + /* FIXME. We apply pcrel relocs as if they were absolute, + ie. without subtracting the pc. This is to suit + display_debug_frames which does not add the pc even + though it ought to for DW_EH_PE_pcrel FDEs. Removing + the hack in display_debug_frames will require that we + apply rel relocs too. */ + byte_put (loc, rp->r_addend + sym->st_value, reloc_size); } free (symtab);