From a15cbb8885cb5bbed4a734850e04c50e371f77fc Mon Sep 17 00:00:00 2001 From: Mark Kettenis Date: Mon, 1 Mar 2004 21:41:52 +0000 Subject: Correctly compute pc-relative relocation addend for amd64. ok deraadt@ --- gnu/usr.bin/binutils/gas/config/tc-i386.c | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) (limited to 'gnu/usr.bin/binutils/gas/config') diff --git a/gnu/usr.bin/binutils/gas/config/tc-i386.c b/gnu/usr.bin/binutils/gas/config/tc-i386.c index 71ddb20a042..2c187675fec 100644 --- a/gnu/usr.bin/binutils/gas/config/tc-i386.c +++ b/gnu/usr.bin/binutils/gas/config/tc-i386.c @@ -4343,6 +4343,8 @@ md_apply_fix3 (fixP, valp, seg) else if (use_rela_relocations) { fixP->fx_no_overflow = 1; + /* Remember value for tc_gen_reloc. */ + fixP->fx_addnumber = value; value = 0; } md_number_to_chars (p, value, fixP->fx_size); @@ -4804,9 +4806,23 @@ tc_gen_reloc (section, fixp) /* Use the rela in 64bit mode. */ else { - rel->addend = fixp->fx_offset; - if (fixp->fx_pcrel) - rel->addend -= fixp->fx_size; + if (!fixp->fx_pcrel) + rel->addend = fixp->fx_offset; + else + switch (code) + { + case BFD_RELOC_X86_64_PLT32: + case BFD_RELOC_X86_64_GOT32: + case BFD_RELOC_X86_64_GOTPCREL: + rel->addend = fixp->fx_offset - fixp->fx_size; + break; + default: + rel->addend = (section->vma + - fixp->fx_size + + fixp->fx_addnumber + + md_pcrel_from (fixp)); + break; + } } rel->howto = bfd_reloc_type_lookup (stdoutput, code); -- cgit v1.2.3