|
@@ -78,9 +78,30 @@ void SoftCPU::dump() const
|
|
|
printf("o=%u s=%u z=%u a=%u p=%u c=%u\n", of(), sf(), zf(), af(), pf(), cf());
|
|
|
}
|
|
|
|
|
|
+u8 SoftCPU::read8()
|
|
|
+{
|
|
|
+ auto value = read_memory8({ cs(), eip() });
|
|
|
+ m_eip += 1;
|
|
|
+ return value;
|
|
|
+}
|
|
|
+
|
|
|
+u16 SoftCPU::read16()
|
|
|
+{
|
|
|
+ auto value = read_memory16({ cs(), eip() });
|
|
|
+ m_eip += 2;
|
|
|
+ return value;
|
|
|
+}
|
|
|
+
|
|
|
+u32 SoftCPU::read32()
|
|
|
+{
|
|
|
+ auto value = read_memory32({ cs(), eip() });
|
|
|
+ m_eip += 4;
|
|
|
+ return value;
|
|
|
+}
|
|
|
+
|
|
|
u8 SoftCPU::read_memory8(X86::LogicalAddress address)
|
|
|
{
|
|
|
- ASSERT(address.selector() == 0x20);
|
|
|
+ ASSERT(address.selector() == 0x18 || address.selector() == 0x20);
|
|
|
auto value = m_emulator.mmu().read8(address.offset());
|
|
|
printf("\033[36;1mread_memory8: @%08x -> %02x\033[0m\n", address.offset(), value);
|
|
|
return value;
|
|
@@ -88,7 +109,7 @@ u8 SoftCPU::read_memory8(X86::LogicalAddress address)
|
|
|
|
|
|
u16 SoftCPU::read_memory16(X86::LogicalAddress address)
|
|
|
{
|
|
|
- ASSERT(address.selector() == 0x20);
|
|
|
+ ASSERT(address.selector() == 0x18 || address.selector() == 0x20);
|
|
|
auto value = m_emulator.mmu().read16(address.offset());
|
|
|
printf("\033[36;1mread_memory16: @%08x -> %04x\033[0m\n", address.offset(), value);
|
|
|
return value;
|
|
@@ -96,7 +117,7 @@ u16 SoftCPU::read_memory16(X86::LogicalAddress address)
|
|
|
|
|
|
u32 SoftCPU::read_memory32(X86::LogicalAddress address)
|
|
|
{
|
|
|
- ASSERT(address.selector() == 0x20);
|
|
|
+ ASSERT(address.selector() == 0x18 || address.selector() == 0x20);
|
|
|
auto value = m_emulator.mmu().read32(address.offset());
|
|
|
printf("\033[36;1mread_memory32: @%08x -> %08x\033[0m\n", address.offset(), value);
|
|
|
return value;
|