2016-07-05 17:28:27 +00:00
|
|
|
//
|
|
|
|
// Commodore1540.cpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 05/07/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "Commodore1540.hpp"
|
2016-07-05 20:39:18 +00:00
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
using namespace Commodore::C1540;
|
|
|
|
|
2016-07-05 21:27:02 +00:00
|
|
|
Machine::Machine()
|
|
|
|
{
|
|
|
|
_serialPortVIA.reset(new SerialPortVIA);
|
|
|
|
_serialPort.reset(new SerialPort);
|
2016-07-05 23:12:43 +00:00
|
|
|
|
2016-07-05 21:27:02 +00:00
|
|
|
_serialPort->set_serial_port_via(_serialPortVIA);
|
2016-07-05 23:12:43 +00:00
|
|
|
_serialPortVIA->set_serial_port(_serialPort);
|
2016-07-05 21:27:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Machine::set_serial_bus(std::shared_ptr<::Commodore::Serial::Bus> serial_bus)
|
|
|
|
{
|
|
|
|
_serialPort->set_serial_bus(serial_bus);
|
|
|
|
serial_bus->add_port(_serialPort);
|
|
|
|
}
|
|
|
|
|
2016-07-05 20:39:18 +00:00
|
|
|
unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uint16_t address, uint8_t *value)
|
|
|
|
{
|
|
|
|
if(address < 0x800)
|
|
|
|
{
|
|
|
|
if(isReadOperation(operation))
|
|
|
|
*value = _ram[address];
|
|
|
|
else
|
|
|
|
_ram[address] = *value;
|
|
|
|
}
|
|
|
|
else if(address >= 0xc000)
|
|
|
|
{
|
|
|
|
if(isReadOperation(operation))
|
|
|
|
*value = _rom[address & 0x3fff];
|
|
|
|
}
|
2016-07-05 21:27:02 +00:00
|
|
|
else if(address >= 0x1800 && address <= 0x180f)
|
|
|
|
{
|
|
|
|
if(isReadOperation(operation))
|
|
|
|
*value = _serialPortVIA->get_register(address);
|
|
|
|
else
|
|
|
|
_serialPortVIA->set_register(address, *value);
|
|
|
|
}
|
|
|
|
|
|
|
|
_serialPortVIA->run_for_half_cycles(2);
|
2016-07-05 20:39:18 +00:00
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2016-07-05 20:54:25 +00:00
|
|
|
void Machine::set_rom(const uint8_t *rom)
|
2016-07-05 20:39:18 +00:00
|
|
|
{
|
|
|
|
memcpy(_rom, rom, sizeof(_rom));
|
|
|
|
}
|
2016-07-05 23:12:43 +00:00
|
|
|
|
|
|
|
#pragma mark - 6522 delegate
|
|
|
|
|
|
|
|
void Machine::mos6522_did_change_interrupt_status(void *mos6522)
|
|
|
|
{
|
|
|
|
set_irq_line(_serialPortVIA->get_interrupt_line());
|
|
|
|
}
|