2020-09-28 21:35:46 -04:00
|
|
|
//
|
|
|
|
// 65816Base.cpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 28/09/2020.
|
|
|
|
// Copyright © 2020 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "../65816.hpp"
|
|
|
|
|
|
|
|
using namespace CPU::WDC65816;
|
|
|
|
|
2023-05-10 18:53:38 -05:00
|
|
|
uint16_t ProcessorBase::value_of(Register r) const {
|
2020-09-28 21:35:46 -04:00
|
|
|
switch (r) {
|
2020-10-15 18:42:38 -04:00
|
|
|
case Register::ProgramCounter: return registers_.pc;
|
2020-09-29 18:42:07 -04:00
|
|
|
case Register::LastOperationAddress: return last_operation_pc_;
|
2022-06-22 15:55:34 -04:00
|
|
|
case Register::StackPointer:
|
|
|
|
return
|
|
|
|
(registers_.s.full & (registers_.emulation_flag ? 0xff : 0xffff)) |
|
|
|
|
(registers_.emulation_flag ? 0x100 : 0x000);
|
2020-10-10 21:33:56 -04:00
|
|
|
case Register::Flags: return get_flags();
|
2020-10-15 18:42:38 -04:00
|
|
|
case Register::A: return registers_.a.full;
|
2020-11-04 20:35:41 -05:00
|
|
|
case Register::X: return registers_.x.full;
|
|
|
|
case Register::Y: return registers_.y.full;
|
2020-10-15 18:42:38 -04:00
|
|
|
case Register::EmulationFlag: return registers_.emulation_flag;
|
|
|
|
case Register::DataBank: return registers_.data_bank >> 16;
|
|
|
|
case Register::ProgramBank: return registers_.program_bank >> 16;
|
|
|
|
case Register::Direct: return registers_.direct;
|
2020-09-28 21:35:46 -04:00
|
|
|
default: return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-10 18:53:38 -05:00
|
|
|
void ProcessorBase::set_value_of(Register r, uint16_t value) {
|
2020-09-28 21:35:46 -04:00
|
|
|
switch (r) {
|
2020-10-15 21:10:32 -04:00
|
|
|
case Register::ProgramCounter: registers_.pc = value; break;
|
|
|
|
case Register::StackPointer: registers_.s.full = value; break;
|
|
|
|
case Register::Flags: set_flags(uint8_t(value)); break;
|
|
|
|
case Register::A: registers_.a.full = value; break;
|
2020-11-04 20:35:41 -05:00
|
|
|
case Register::X: registers_.x.full = value & registers_.x_mask; break;
|
|
|
|
case Register::Y: registers_.y.full = value & registers_.x_mask; break;
|
2020-10-15 21:10:32 -04:00
|
|
|
case Register::EmulationFlag: set_emulation_mode(value); break;
|
|
|
|
case Register::DataBank: registers_.data_bank = uint32_t(value & 0xff) << 16; break;
|
|
|
|
case Register::ProgramBank: registers_.program_bank = uint32_t(value &0xff) << 16; break;
|
|
|
|
case Register::Direct: registers_.direct = value; break;
|
2020-09-28 21:35:46 -04:00
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
}
|