Related articles |
---|
Borland Turbo C 2.0 for Atari 68000 machines: ODD behavior carter@cs.wisc.edu (1991-04-06) |
Re: Borland Turbo C 2.0 for Atari 68000 machines: ODD behavior ckp@grebyn.com (1991-04-08) |
Re: Borland Turbo C 2.0 for Atari 68000 machines: ODD behavior albaugh@dms.UUCP (1991-04-09) |
Re: Borland Turbo C 2.0 for Atari 68000 machines: ODD behavior pardo@june.cs.washington.edu (1991-04-12) |
Newsgroups: | comp.compilers,comp.lang.c |
From: | ckp@grebyn.com (Checkpoint Technologies) |
Summary: | Skip this if you're not into 68Ks |
Keywords: | C, code, |
Organization: | Grebyn Timesharing |
References: | <1991Apr6.091013.26131@daffy.cs.wisc.edu> |
Date: | Mon, 8 Apr 1991 13:33:07 GMT |
In article <1991Apr6.091013.26131@daffy.cs.wisc.edu> carter@cs.wisc.edu (Gregory Carter) writes:
> (unsigned int)(*((unsigned int *)0x00ff8e20L)) = 0x03;
> MOVE.W #$0003, $00ff8e20
>...
> (unsigned int)(*((unsigned int *)0xffff8e20L)) = 0x03;
> MOVE.W #$0003, $8e20
>
>This is obviously not correct.
This may not be obvious, but it *is* correct. The compiler is doing you a
favor.
The 68K has "absolute short" and "absolute long" addressing. Absolute
long means that a whole 32 bit absoluet address follows.
Absolute short means that only a 16 bit word follows, and it should be
*sign extended* to 32 bits before being used.
The value $8E20, when sign extended into a full 32 bit address becomes
$FFFF8E20. This is just what you asked for, and the compiler found a
briefer way to code it.
--
ckp@grebyn.com
[brychcy@informatik.tu-muenchen.dbp.de (Till Brychcy) also pointed this out.
-John]
--
Return to the
comp.compilers page.
Search the
comp.compilers archives again.