From 8ad607885008d471bdb40901b18cc46f7be7fb69 Mon Sep 17 00:00:00 2001 From: Michael Meissner Date: Mon, 12 May 1997 02:04:02 +0000 Subject: [PATCH] Fix endian problems with ld.d/st.d --- sim/tic80/ChangeLog | 1 + sim/tic80/insns | 10 ++++++++-- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/sim/tic80/ChangeLog b/sim/tic80/ChangeLog index b22b9d38ba..ac4ffa5882 100644 --- a/sim/tic80/ChangeLog +++ b/sim/tic80/ChangeLog @@ -11,6 +11,7 @@ Sun May 11 10:25:14 1997 Michael Meissner 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 diff --git a/sim/tic80/insns b/sim/tic80/insns index 396dcd6ed9..5a4110bedf 100644 --- a/sim/tic80/insns +++ b/sim/tic80/insns @@ -633,6 +633,7 @@ instruction_address::function::do_jsr:instruction_address nia, signed32 *rLink, // 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: @@ -660,7 +661,9 @@ void::function::do_ld:int Dest, unsigned32 Base, unsigned32 *rBase, int m , int 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; @@ -895,6 +898,7 @@ void::function::do_shift:int Dest, int Source, int Merge, int i, int n, int EndM // 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: @@ -914,7 +918,9 @@ void::function::do_st:int Source, unsigned32 Base, unsigned32 *rBase, int m , in 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; -- 2.34.1