about summary refs log tree commit diff stats
path: root/subx/011direct_addressing.cc
diff options
context:
space:
mode:
authorKartik Agaram <vc@akkartik.com>2018-07-08 22:33:15 -0700
committerKartik Agaram <vc@akkartik.com>2018-07-08 22:33:15 -0700
commit665a4d70406a201bb8481fde0c9fbbead3477f00 (patch)
treed65faba2b6cda9e1920debc44d013bf3b86803b2 /subx/011direct_addressing.cc
parentb0f89e4f9b204fa28fc02f6335dbf654d7a4dcf1 (diff)
downloadmu-665a4d70406a201bb8481fde0c9fbbead3477f00.tar.gz
4327
Encapsulate RAM management.
Diffstat (limited to 'subx/011direct_addressing.cc')
-rw-r--r--subx/011direct_addressing.cc8
1 files changed, 4 insertions, 4 deletions
diff --git a/subx/011direct_addressing.cc b/subx/011direct_addressing.cc
index 5ce620ad..1e0375f6 100644
--- a/subx/011direct_addressing.cc
+++ b/subx/011direct_addressing.cc
@@ -42,7 +42,7 @@ int32_t* effective_address(uint8_t modrm) {
   //: other mods are indirect, and they'll set addr appropriately
   assert(addr > 0);
   assert(addr + sizeof(int32_t) <= Mem.size());
-  return reinterpret_cast<int32_t*>(&Mem.at(addr));  // rely on the host itself being in little-endian order
+  return mem_addr_i32(addr);
 }
 
 //:: subtract
@@ -284,14 +284,14 @@ void push(uint32_t val) {
   Reg[ESP].u -= 4;
   trace(2, "run") << "decrementing ESP to 0x" << HEXWORD << Reg[ESP].u << end();
   trace(2, "run") << "pushing value 0x" << HEXWORD << val << end();
-  *reinterpret_cast<uint32_t*>(&Mem.at(Reg[ESP].u)) = val;
+  write_mem_u32(Reg[ESP].u, val);
 }
 
 //:: pop
 
 :(scenario pop_r32)
 % Reg[ESP].u = 0x60;
-% SET_WORD_IN_MEM(0x60, 0x0000000a);
+% write_mem_i32(0x60, 0x0000000a);
 # op  ModR/M  SIB   displacement  immediate
   5b                                          # pop stack to EBX
 +run: pop into EBX
@@ -314,7 +314,7 @@ case 0x5f: {  // pop stack into r32
 }
 :(code)
 uint32_t pop() {
-  uint32_t result = *reinterpret_cast<uint32_t*>(&Mem.at(Reg[ESP].u));
+  uint32_t result = read_mem_u32(Reg[ESP].u);
   trace(2, "run") << "popping value 0x" << HEXWORD << result << end();
   Reg[ESP].u += 4;
   trace(2, "run") << "incrementing ESP to 0x" << HEXWORD << Reg[ESP].u << end();