mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-12 00:30:31 +00:00
Decode MOVE and the fixed 0x4xxx set.
This commit is contained in:
parent
89b8b59658
commit
faa35fe9fc
@ -229,9 +229,19 @@ template <uint8_t op, bool validate> Preinstruction Predecoder<model>::decode(ui
|
|||||||
AddressingMode::AddressRegisterIndirectWithDisplacement, ea_register);
|
AddressingMode::AddressRegisterIndirectWithDisplacement, ea_register);
|
||||||
|
|
||||||
//
|
//
|
||||||
// MARK: STOP
|
// MARK: MOVE
|
||||||
//
|
//
|
||||||
case Op(Operation::STOP):
|
case Op(Operation::MOVEb): case Op(Operation::MOVEl): case Op(Operation::MOVEw):
|
||||||
|
return Preinstruction(operation,
|
||||||
|
ea_combined_mode, ea_register,
|
||||||
|
combined_mode<false, false>(opmode, data_register), data_register);
|
||||||
|
|
||||||
|
//
|
||||||
|
// MARK: STOP, RESET, NOP RTE, RTS, TRAPV, RTR
|
||||||
|
//
|
||||||
|
case Op(Operation::STOP): case Op(Operation::RESET): case Op(Operation::NOP):
|
||||||
|
case Op(Operation::RTE): case Op(Operation::RTS): case Op(Operation::TRAPV):
|
||||||
|
case Op(Operation::RTR):
|
||||||
return Preinstruction(operation);
|
return Preinstruction(operation);
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -336,17 +346,20 @@ Preinstruction Predecoder<model>::decode0(uint16_t instruction) {
|
|||||||
|
|
||||||
template <Model model>
|
template <Model model>
|
||||||
Preinstruction Predecoder<model>::decode1(uint16_t instruction) {
|
Preinstruction Predecoder<model>::decode1(uint16_t instruction) {
|
||||||
|
// 4-116 (p220)
|
||||||
DecodeOp(MOVEb);
|
DecodeOp(MOVEb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template <Model model>
|
template <Model model>
|
||||||
Preinstruction Predecoder<model>::decode2(uint16_t instruction) {
|
Preinstruction Predecoder<model>::decode2(uint16_t instruction) {
|
||||||
|
// 4-116 (p220)
|
||||||
DecodeOp(MOVEl);
|
DecodeOp(MOVEl);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <Model model>
|
template <Model model>
|
||||||
Preinstruction Predecoder<model>::decode3(uint16_t instruction) {
|
Preinstruction Predecoder<model>::decode3(uint16_t instruction) {
|
||||||
|
// 4-116 (p220)
|
||||||
DecodeOp(MOVEw);
|
DecodeOp(MOVEw);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -354,7 +367,7 @@ template <Model model>
|
|||||||
Preinstruction Predecoder<model>::decode4(uint16_t instruction) {
|
Preinstruction Predecoder<model>::decode4(uint16_t instruction) {
|
||||||
switch(instruction & 0xfff) {
|
switch(instruction & 0xfff) {
|
||||||
case 0xe70: DecodeOp(RESET); // 6-83 (p537)
|
case 0xe70: DecodeOp(RESET); // 6-83 (p537)
|
||||||
case 0xe71: DecodeOp(NOP); // 8-13 (p469)
|
case 0xe71: DecodeOp(NOP); // 4-147 (p251)
|
||||||
case 0xe73: DecodeOp(RTE); // 6-84 (p538)
|
case 0xe73: DecodeOp(RTE); // 6-84 (p538)
|
||||||
case 0xe75: DecodeOp(RTS); // 4-169 (p273)
|
case 0xe75: DecodeOp(RTS); // 4-169 (p273)
|
||||||
case 0xe76: DecodeOp(TRAPV); // 4-191 (p295)
|
case 0xe76: DecodeOp(TRAPV); // 4-191 (p295)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user