1
0
mirror of https://github.com/TomHarte/CLK.git synced 2024-12-02 17:51:12 +00:00
CLK/OSBindings/Mac/Clock SignalTests/Bridges/MOS6522Bridge.mm

75 lines
1.3 KiB
Plaintext
Raw Normal View History

//
// MOS6522Bridge.m
// Clock Signal
//
// Created by Thomas Harte on 18/06/2016.
// Copyright © 2016 Thomas Harte. All rights reserved.
//
#import "MOS6522Bridge.h"
#include "6522.hpp"
@class MOS6522Bridge;
class VanillaVIA: public MOS::MOS6522<VanillaVIA> {
public:
MOS6522Bridge *bridge;
bool irq_line;
uint8_t port_a_value;
uint8_t port_b_value;
2017-07-25 02:33:49 +00:00
void set_interrupt_status(bool new_status) {
irq_line = new_status;
}
2017-07-25 02:33:49 +00:00
uint8_t get_port_input(Port port) {
return port ? port_b_value : port_a_value;
}
};
2017-07-25 02:33:49 +00:00
@implementation MOS6522Bridge {
VanillaVIA _via;
}
2017-07-25 02:33:49 +00:00
- (instancetype)init {
self = [super init];
2017-07-25 02:33:49 +00:00
if(self) {
_via.bridge = self;
}
return self;
}
2017-07-25 02:33:49 +00:00
- (void)setValue:(uint8_t)value forRegister:(NSUInteger)registerNumber {
_via.set_register((int)registerNumber, value);
}
2017-07-25 02:33:49 +00:00
- (uint8_t)valueForRegister:(NSUInteger)registerNumber {
return _via.get_register((int)registerNumber);
}
2017-07-25 02:33:49 +00:00
- (void)runForHalfCycles:(NSUInteger)numberOfHalfCycles {
_via.run_for(HalfCycles((int)numberOfHalfCycles));
}
2017-07-25 02:33:49 +00:00
- (BOOL)irqLine {
return _via.irq_line;
}
2017-07-25 02:33:49 +00:00
- (void)setPortAInput:(uint8_t)portAInput {
_via.port_a_value = portAInput;
}
2017-07-25 02:33:49 +00:00
- (uint8_t)portAInput {
return _via.port_a_value;
}
2017-07-25 02:33:49 +00:00
- (void)setPortBInput:(uint8_t)portBInput {
_via.port_b_value = portBInput;
}
2017-07-25 02:33:49 +00:00
- (uint8_t)portBInput {
return _via.port_b_value;
}
@end