2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveMemReg(Size size) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
modRM();
|
|
|
|
setMem(size, getReg(size));
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveRegMem(Size size) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
modRM();
|
|
|
|
setReg(size, getMem(size));
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveMemSeg() -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
modRM();
|
|
|
|
setMem(Word, getSeg());
|
2016-02-04 21:18:06 +00:00
|
|
|
state.poll = false;
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveSegMem() -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
wait(1);
|
|
|
|
modRM();
|
|
|
|
setSeg(getMem(Word));
|
2016-02-04 21:18:06 +00:00
|
|
|
if((modrm.reg & 3) == 3) state.poll = false;
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveAccMem(Size size) -> void {
|
2016-02-04 21:18:06 +00:00
|
|
|
setAcc(size, read(size, segment(r.ds), fetch(Word)));
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveMemAcc(Size size) -> void {
|
2016-02-04 21:18:06 +00:00
|
|
|
write(size, segment(r.ds), fetch(Word), getAcc(size));
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveRegImm(uint8_t& reg) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
reg = fetch(Byte);
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveRegImm(uint16_t& reg) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
reg = fetch(Word);
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionMoveMemImm(Size size) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
modRM();
|
|
|
|
setMem(size, fetch(size));
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionExchange(uint16_t& x, uint16_t& y) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
wait(2);
|
|
|
|
uint16 z = x;
|
|
|
|
x = y;
|
|
|
|
y = z;
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionExchangeMemReg(Size size) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
wait(2);
|
|
|
|
modRM();
|
|
|
|
auto mem = getMem(size);
|
|
|
|
auto reg = getReg(size);
|
|
|
|
setMem(size, reg);
|
|
|
|
setReg(size, mem);
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionLoadEffectiveAddressRegMem() -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
modRM();
|
|
|
|
setReg(Word, modrm.address);
|
|
|
|
}
|
|
|
|
|
2017-08-10 11:26:02 +00:00
|
|
|
auto V30MZ::instructionLoadSegmentMem(uint16_t& segment) -> void {
|
2016-02-04 10:29:08 +00:00
|
|
|
wait(5);
|
|
|
|
modRM();
|
2016-03-10 10:35:48 +00:00
|
|
|
setReg(Word, getMem(Word));
|
|
|
|
segment = getMem(Word, 2);
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|