From: Alan Modra Date: Fri, 4 Jul 2008 13:04:04 +0000 (+0000) Subject: * config/tc-spu.c (md_apply_fix): Handle fully resolved X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d62f07d07da0af73891c4479c8e233968b0a3606;p=binutils-gdb.git * config/tc-spu.c (md_apply_fix): Handle fully resolved BFD_RELOC_32_PCREL, BFD_RELOC_SPU_HI16 and BFD_RELOC_SPU_LO16. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 27a50dc27e0..a06d2090e58 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +2008-07-04 Alan Modra + + * config/tc-spu.c (md_apply_fix): Handle fully resolved + BFD_RELOC_32_PCREL, BFD_RELOC_SPU_HI16 and BFD_RELOC_SPU_LO16. + 2008-06-25 Peter Bergner * config/tc-ppc.c (parse_cpu): Handle -m464. diff --git a/gas/config/tc-spu.c b/gas/config/tc-spu.c index c5a44cedb9c..3b579d41517 100644 --- a/gas/config/tc-spu.c +++ b/gas/config/tc-spu.c @@ -964,6 +964,7 @@ md_apply_fix (fixS *fixP, valueT *valP, segT seg ATTRIBUTE_UNUSED) return; case BFD_RELOC_32: + case BFD_RELOC_32_PCREL: md_number_to_chars (place, val, 4); return; @@ -1011,6 +1012,14 @@ md_apply_fix (fixS *fixP, valueT *valP, segT seg ATTRIBUTE_UNUSED) res = (val & 0x3fffc) << 5; break; + case BFD_RELOC_SPU_HI16: + res = (val >> 9) & 0x7fff80; + break; + + case BFD_RELOC_SPU_LO16: + res = (val << 7) & 0x7fff80; + break; + default: as_bad_where (fixP->fx_file, fixP->fx_line, _("reloc %d not supported by object file format"),