mirror of
https://github.com/TomHarte/CLK.git
synced 2024-10-20 06:25:01 +00:00
121 lines
2.5 KiB
C++
121 lines
2.5 KiB
C++
//
|
|
// ZX8081.cpp
|
|
// Clock Signal
|
|
//
|
|
// Created by Thomas Harte on 04/06/2017.
|
|
// Copyright © 2017 Thomas Harte. All rights reserved.
|
|
//
|
|
|
|
#include "ZX8081.hpp"
|
|
|
|
using namespace ZX8081;
|
|
|
|
Machine::Machine() :
|
|
vertical_sync_(false),
|
|
ram_(65536) {
|
|
// run at 3.25 Mhz
|
|
set_clock_rate(3250000);
|
|
}
|
|
|
|
int Machine::perform_machine_cycle(const CPU::Z80::MachineCycle &cycle) {
|
|
cycles_since_display_update_ += cycle.length;
|
|
|
|
uint8_t r;
|
|
switch(cycle.operation) {
|
|
case CPU::Z80::BusOperation::Output:
|
|
if(*cycle.address == 0xff) {
|
|
update_display();
|
|
set_sync(false);
|
|
}
|
|
break;
|
|
|
|
case CPU::Z80::BusOperation::Input:
|
|
if(*cycle.address == 0xfe) {
|
|
update_display();
|
|
set_sync(true);
|
|
}
|
|
break;
|
|
|
|
case CPU::Z80::BusOperation::Interrupt:
|
|
*cycle.value = 0xff;
|
|
break;
|
|
|
|
case CPU::Z80::BusOperation::ReadOpcode:
|
|
r = (uint8_t)get_value_of_register(CPU::Z80::Register::R);
|
|
set_interrupt_line(!(r & 0x40));
|
|
case CPU::Z80::BusOperation::Read:
|
|
if(*cycle.address < rom_.size()) *cycle.value = rom_[*cycle.address];
|
|
else {
|
|
uint8_t value = ram_[*cycle.address];
|
|
if(*cycle.address > 32768 && !(value & 0x40) && cycle.operation == CPU::Z80::BusOperation::ReadOpcode) {
|
|
// TODO: character lookup.
|
|
output_byte(value);
|
|
*cycle.value = 0;
|
|
}
|
|
else *cycle.value = value;
|
|
}
|
|
break;
|
|
|
|
case CPU::Z80::BusOperation::Write:
|
|
ram_[*cycle.address] = *cycle.value;
|
|
break;
|
|
|
|
default: break;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
void Machine::setup_output(float aspect_ratio) {
|
|
crt_.reset(new Outputs::CRT::CRT(207, 1, Outputs::CRT::DisplayType::PAL50, 1));
|
|
crt_->set_rgb_sampling_function(
|
|
"vec3 rgb_sample(usampler2D sampler, vec2 coordinate, vec2 icoordinate)"
|
|
"{"
|
|
"return vec3(1.0);"
|
|
"}");
|
|
}
|
|
|
|
void Machine::flush() {
|
|
update_display();
|
|
}
|
|
|
|
void Machine::close_output() {
|
|
}
|
|
|
|
std::shared_ptr<Outputs::CRT::CRT> Machine::get_crt() {
|
|
return crt_;
|
|
}
|
|
|
|
std::shared_ptr<Outputs::Speaker> Machine::get_speaker() {
|
|
return nullptr;
|
|
}
|
|
|
|
void Machine::run_for_cycles(int number_of_cycles) {
|
|
CPU::Z80::Processor<Machine>::run_for_cycles(number_of_cycles);
|
|
}
|
|
|
|
void Machine::configure_as_target(const StaticAnalyser::Target &target) {
|
|
// TODO: pay attention to the target
|
|
rom_ = zx80_rom_;
|
|
}
|
|
|
|
void Machine::set_rom(ROMType type, std::vector<uint8_t> data) {
|
|
switch(type) {
|
|
case ZX80: zx80_rom_ = data; break;
|
|
case ZX81: zx81_rom_ = data; break;
|
|
}
|
|
}
|
|
|
|
#pragma mark - Video
|
|
|
|
void Machine::update_display() {
|
|
// TODO.
|
|
cycles_since_display_update_ = 0;
|
|
}
|
|
|
|
void Machine::set_sync(bool sync) {
|
|
}
|
|
|
|
void Machine::output_byte(uint8_t byte) {
|
|
}
|