This is the mail archive of the
cgen@sourceware.org
mailing list for the CGEN project.
Re: [PATCH] m32r-*-as For a code depended for host word size.
- From: Andreas Schwab <schwab at suse dot de>
- To: Kazuhiro Inaoka <inaoka dot kazuhiro at renesas dot com>
- Cc: Nick Clifton <nickc at redhat dot com>, binutils at sources dot redhat dot com,cgen at sources dot redhat dot com
- Date: Fri, 14 Oct 2005 11:03:56 +0200
- Subject: Re: [PATCH] m32r-*-as For a code depended for host word size.
- References: <434F6596.404@renesas.com>
Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com> writes:
> 2005-10-14 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
>
> * cpu/m32r.opc (parse_slo16): Changed for a code depended
> for host word size.
> Index: m32r.opc
> ===================================================================
> RCS file: /cvs/src/src/cpu/m32r.opc,v
> retrieving revision 1.6
> diff -u -p -r1.6 m32r.opc
> --- m32r.opc 1 Jul 2005 11:16:30 -0000 1.6
> +++ m32r.opc 14 Oct 2005 07:33:21 -0000
> @@ -182,7 +182,7 @@ parse_slo16 (CGEN_CPU_DESC cd,
> {
> value &= 0xffff;
> if (value & 0x8000)
> - value |= 0xffff0000;
> + value |= ~0xffff;
~0xffff is still 0xffff0000 for 32 bit ints and will be zero extended.
You probably want ~(bfd_vma)0xffff here. Alternatively you can use
value = ((value & 0xffff) ^ 0x8000) - 0x8000.
Andreas.
--
Andreas Schwab, SuSE Labs, schwab@suse.de
SuSE Linux Products GmbH, Maxfeldstraße 5, 90409 Nürnberg, Germany
Key fingerprint = 58CA 54C7 6D53 942B 1756 01D3 44D5 214B 8276 4ED5
"And now for something completely different."