2016-06-05 01:43:50 +00:00
|
|
|
//
|
|
|
|
// Vic20.cpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 04/06/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "Vic20.hpp"
|
2016-06-05 02:00:50 +00:00
|
|
|
|
2016-06-05 14:51:07 +00:00
|
|
|
#include <algorithm>
|
|
|
|
|
2016-06-05 02:00:50 +00:00
|
|
|
using namespace Vic20;
|
|
|
|
|
2016-06-05 14:51:07 +00:00
|
|
|
Machine::Machine()
|
|
|
|
{}
|
|
|
|
|
2016-06-05 02:00:50 +00:00
|
|
|
unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uint16_t address, uint8_t *value)
|
|
|
|
{
|
|
|
|
return 1;
|
|
|
|
}
|
2016-06-05 13:06:59 +00:00
|
|
|
|
2016-06-05 14:51:07 +00:00
|
|
|
void Machine::setup_output(float aspect_ratio)
|
|
|
|
{
|
|
|
|
_mos6560 = std::unique_ptr<MOS::MOS6560>(new MOS::MOS6560());
|
|
|
|
}
|
|
|
|
|
2016-06-05 13:06:59 +00:00
|
|
|
void Machine::set_rom(ROMSlot slot, size_t length, const uint8_t *data)
|
|
|
|
{
|
2016-06-05 14:51:07 +00:00
|
|
|
uint8_t *target = nullptr;
|
|
|
|
switch(slot)
|
|
|
|
{
|
|
|
|
case ROMSlotKernel: target = _kernelROM; break;
|
|
|
|
case ROMSlotCharacters: target = _characterROM; break;
|
|
|
|
case ROMSlotBASIC: target = _basicROM; break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(target)
|
|
|
|
{
|
|
|
|
size_t length_to_copy = std::max((size_t)0x1000, length);
|
|
|
|
memcpy(target, data, length_to_copy);
|
|
|
|
}
|
2016-06-05 13:06:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Machine::add_prg(size_t length, const uint8_t *data)
|
|
|
|
{
|
|
|
|
}
|