instead of TRACE_ALU2.
(sl r): Use EndMask as is, instead of using Source+1 register.
(subu): Operands are unsigned, not signed.
+ (do_{ld,st}): Fix endian problems with ld.d/st.d.
Sat May 10 12:35:47 1997 Michael Meissner <meissner@cygnus.com>
// ld[{.b.h.d}]
void::function::do_ld:int Dest, unsigned32 Base, unsigned32 *rBase, int m , int sz, int S, unsigned32 Offset
unsigned32 addr;
+ unsigned64 u64;
switch (sz)
{
case 0:
addr = Base + (S ? (Offset << 3) : Offset);
if (m)
*rBase = addr;
- *(unsigned64*)(&GPR(Dest)) = MEM (signed, addr, 8);
+ u64 = MEM (signed, addr, 8);
+ GPR(Dest) = (unsigned32) u64;
+ GPR(Dest+1) = (unsigned32) (u64 >> 32);
break;
default:
addr = -1;
// st[{.b|.h|.d}]
void::function::do_st:int Source, unsigned32 Base, unsigned32 *rBase, int m , int sz, int S, unsigned32 Offset
unsigned32 addr;
+ unsigned64 u64;
switch (sz)
{
case 0:
engine_error (SD, CPU, cia, "0x%lx: st.d with odd source register %d",
cia.ip, Source);
addr = Base + (S ? (Offset << 3) : Offset);
- STORE (addr, 8, *(unsigned64*)&GPR(Source));
+ u64 = GPR (Source);
+ u64 |= (((unsigned64) GPR (Source+1)) << 32);
+ STORE (addr, 8, u64);
break;
default:
addr = -1;