From: Dimitar Dimitrov Date: Mon, 2 Jan 2017 16:20:21 +0000 (+0200) Subject: Fix PRU GAS for 32-bit hosts X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ddb2c6fdfc79e83af07ebdc93bdd17fe1eede8e7;p=binutils-gdb.git Fix PRU GAS for 32-bit hosts The PRU GAS port I originally submitted does not build on 32bit hosts. This patch fixes it by aligning md_number_to_chars's definition with the global declaration in tc.h. Here is the original bug report I got: https://github.com/rcn-ee/repos/pull/23#issuecomment-269915175 * config/tc-pru.c (md_number_to_chars): Fix parameter to be valueT, as declared in tc.h. (md_apply_fix): Fix to work on 32-bit hosts. Signed-off-by: Dimitar Dimitrov --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 6a61d61fee1..fccd817572f 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,9 @@ +2017-01-03 Dimitar Dimitrov + + * config/tc-pru.c (md_number_to_chars): Fix parameter to be + valueT, as declared in tc.h. + (md_apply_fix): Fix to work on 32-bit hosts. + 2017-01-02 Alan Modra Update year range in copyright notice of all files. diff --git a/gas/config/tc-pru.c b/gas/config/tc-pru.c index dfc6f76801d..5bfd67632a8 100644 --- a/gas/config/tc-pru.c +++ b/gas/config/tc-pru.c @@ -175,7 +175,7 @@ md_chars_to_number (char *buf, int n) into the series of bytes that represent the number on the target machine. */ void -md_number_to_chars (char *buf, uint64_t val, int n) +md_number_to_chars (char *buf, valueT val, int n) { gas_assert (n == 1 || n == 2 || n == 4 || n == 8); number_to_chars_littleendian (buf, val, n); @@ -808,20 +808,25 @@ md_apply_fix (fixS *fixP, valueT *valP, segT seg ATTRIBUTE_UNUSED) /* Fix up the instruction. Non-contiguous bitfields need special handling. */ - if (fixP->fx_r_type == BFD_RELOC_PRU_S10_PCREL) - SET_BROFF_URAW (insn, fixup); - else if (fixP->fx_r_type == BFD_RELOC_PRU_LDI32) + if (fixP->fx_r_type == BFD_RELOC_PRU_LDI32) { /* As the only 64-bit "insn", LDI32 needs special handling. */ uint32_t insn1 = insn & 0xffffffff; uint32_t insn2 = insn >> 32; SET_INSN_FIELD (IMM16, insn1, fixup & 0xffff); SET_INSN_FIELD (IMM16, insn2, fixup >> 16); - insn = insn1 | ((uint64_t)insn2 << 32); + + md_number_to_chars (buf, insn1, 4); + md_number_to_chars (buf + 4, insn2, 4); } else - insn = (insn & ~howto->dst_mask) | (fixup << howto->bitpos); - md_number_to_chars (buf, insn, fixP->fx_size); + { + if (fixP->fx_r_type == BFD_RELOC_PRU_S10_PCREL) + SET_BROFF_URAW (insn, fixup); + else + insn = (insn & ~howto->dst_mask) | (fixup << howto->bitpos); + md_number_to_chars (buf, insn, fixP->fx_size); + } } fixP->fx_done = 1;