mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-15 05:31:30 +00:00
Implements direction registers.
This commit is contained in:
parent
f50e8b5106
commit
5eddc92846
@ -73,8 +73,13 @@ uint8_t Executor::read(uint16_t address) {
|
||||
|
||||
// Ports P0–P3.
|
||||
case 0xe0: case 0xe2:
|
||||
case 0xe4: case 0xe8:
|
||||
return port_handler_.get_port_input(port_remap[(address - 0xe0) >> 1]);
|
||||
case 0xe4: case 0xe8: {
|
||||
const int port = port_remap[(address - 0xe0) >> 1];
|
||||
const uint8_t input = port_handler_.get_port_input(port);
|
||||
|
||||
// In the direction registers, a 0 indicates input, a 1 indicates output.
|
||||
return (input &~ port_directions_[port]) | (port_outputs_[port] & port_directions_[port]);
|
||||
}
|
||||
|
||||
case 0xe1: case 0xe3:
|
||||
case 0xe5: case 0xe9:
|
||||
@ -109,12 +114,15 @@ void Executor::write(uint16_t address, uint8_t value) {
|
||||
|
||||
// Ports P0–P3.
|
||||
case 0xe0: case 0xe2:
|
||||
case 0xe4: case 0xe8:
|
||||
return port_handler_.set_port_output(port_remap[(address - 0xe0) >> 1], value);
|
||||
case 0xe4: case 0xe8: {
|
||||
const int port = port_remap[(address - 0xe0) >> 1];
|
||||
port_outputs_[port] = value;
|
||||
return port_handler_.set_port_output(port, value);
|
||||
}
|
||||
|
||||
case 0xe1: case 0xe3:
|
||||
case 0xe5: case 0xe9:
|
||||
// printf("TODO: Ports P0–P3 direction [w %04x %02x]\n", address, value);
|
||||
port_directions_[port_remap[(address - 0xe0) >> 1]] = value;
|
||||
break;
|
||||
|
||||
// Timers.
|
||||
|
@ -136,6 +136,9 @@ class Executor: public CachingExecutor {
|
||||
bool index_mode_ = false;
|
||||
bool decimal_mode_ = false;
|
||||
|
||||
uint8_t port_directions_[4] = {0xff, 0xff, 0xff, 0xff};
|
||||
uint8_t port_outputs_[4] = {0xff, 0xff, 0xff, 0xff};
|
||||
|
||||
inline uint8_t read(uint16_t address);
|
||||
inline void write(uint16_t address, uint8_t value);
|
||||
inline void push(uint8_t value);
|
||||
|
Loading…
x
Reference in New Issue
Block a user