2026-02-05 00:42:25 +01:00
|
|
|
#include "DataTransfer.h"
|
|
|
|
|
|
|
|
|
|
#include "ExecutorCases.h"
|
|
|
|
|
#include "Instruction.h"
|
2026-02-06 19:20:42 +01:00
|
|
|
#include "CPUContext.h"
|
2026-02-05 14:57:23 +01:00
|
|
|
#include "Bus.h"
|
|
|
|
|
|
|
|
|
|
#include <iostream>
|
2026-02-05 00:42:25 +01:00
|
|
|
|
|
|
|
|
namespace executor_cases {
|
2026-02-07 00:16:48 +01:00
|
|
|
|
2026-02-05 14:57:23 +01:00
|
|
|
void Mov_rm32_r32(CPUContext& cc) {
|
2026-02-10 14:57:55 +01:00
|
|
|
x86::ModRM modrm = cc.m_Instruction.m_ModRM;
|
2026-02-05 14:57:23 +01:00
|
|
|
|
|
|
|
|
std::cout << "[Instruction] ";
|
|
|
|
|
|
|
|
|
|
switch(modrm.m_State) {
|
|
|
|
|
case x86::ModRMState::R:
|
|
|
|
|
cc.m_Registers[modrm.m_Rm] = cc.m_Registers[modrm.m_Reg];
|
|
|
|
|
std::cout << "mov " << x86::Register2Str((x86::Register)modrm.m_Rm) << ", " << x86::Register2Str((x86::Register)modrm.m_Rm);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
cc.m_Bus->WriteX<uint32_t>(helpers::ResolveModRMAddress(cc), cc.m_Registers[modrm.m_Reg]);
|
|
|
|
|
std::cout << "mov DWORD PTR [0x" << helpers::ResolveModRMAddress(cc) << "], " << x86::Register2Str((x86::Register)modrm.m_Reg);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
std::cout << std::endl;
|
|
|
|
|
}
|
2026-02-05 00:42:25 +01:00
|
|
|
}
|