1
0
mirror of https://github.com/TomHarte/CLK.git synced 2024-12-11 15:49:38 +00:00
CLK/Machines/Atari/2600/Cartridges/ActivisionStack.hpp

52 lines
1.3 KiB
C++
Raw Normal View History

2017-03-18 22:03:48 +00:00
//
// CartridgeActivisionStack.h
// Clock Signal
//
// Created by Thomas Harte on 18/03/2017.
// Copyright 2017 Thomas Harte. All rights reserved.
2017-03-18 22:03:48 +00:00
//
#ifndef Atari2600_ActivisionStack_hpp
#define Atari2600_ActivisionStack_hpp
2017-03-18 22:03:48 +00:00
namespace Atari2600 {
namespace Cartridge {
2017-03-18 22:03:48 +00:00
class ActivisionStack: public BusExtender {
2017-03-18 22:03:48 +00:00
public:
ActivisionStack(uint8_t *rom_base, std::size_t rom_size) :
BusExtender(rom_base, rom_size),
rom_ptr_(rom_base),
last_opcode_(0x00) {}
2017-03-18 22:03:48 +00:00
void perform_bus_operation(CPU::MOS6502::BusOperation operation, uint16_t address, uint8_t *value) {
2017-03-18 22:03:48 +00:00
if(!(address & 0x1000)) return;
// This is a bit of a hack; a real cartridge can't see either the sync or read lines, and can't see
// address line 13. Instead it looks for a pattern in recent address accesses that would imply an
// RST or JSR.
if(operation == CPU::MOS6502::BusOperation::ReadOpcode && (last_opcode_ == 0x20 || last_opcode_ == 0x60)) {
2017-03-18 22:03:48 +00:00
if(address & 0x2000) {
rom_ptr_ = rom_base_;
2017-03-18 22:03:48 +00:00
} else {
rom_ptr_ = rom_base_ + 4096;
2017-03-18 22:03:48 +00:00
}
}
if(isReadOperation(operation)) {
*value = rom_ptr_[address & 4095];
}
if(operation == CPU::MOS6502::BusOperation::ReadOpcode) last_opcode_ = *value;
2017-03-18 22:03:48 +00:00
}
private:
uint8_t *rom_ptr_;
uint8_t last_opcode_;
};
}
2017-03-18 22:03:48 +00:00
}
#endif /* Atari2600_CartridgeActivisionStack_hpp */