2018-01-05 03:18:18 +00:00
|
|
|
//
|
|
|
|
// KonamiWithSCC.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 04/01/2018.
|
2018-05-13 19:19:52 +00:00
|
|
|
// Copyright 2018 Thomas Harte. All rights reserved.
|
2018-01-05 03:18:18 +00:00
|
|
|
//
|
|
|
|
|
2024-01-17 04:34:46 +00:00
|
|
|
#pragma once
|
2018-01-05 03:18:18 +00:00
|
|
|
|
2023-01-13 04:01:11 +00:00
|
|
|
#include "../MemorySlotHandler.hpp"
|
2018-01-07 01:15:55 +00:00
|
|
|
#include "../../../Components/KonamiSCC/KonamiSCC.hpp"
|
2018-01-05 03:18:18 +00:00
|
|
|
|
2024-01-17 04:34:46 +00:00
|
|
|
namespace MSX::Cartridge {
|
2018-01-05 03:18:18 +00:00
|
|
|
|
2023-01-13 04:02:24 +00:00
|
|
|
class KonamiWithSCCROMSlotHandler: public MemorySlotHandler {
|
2018-01-05 03:18:18 +00:00
|
|
|
public:
|
2023-01-13 04:01:11 +00:00
|
|
|
KonamiWithSCCROMSlotHandler(MSX::MemorySlot &slot, Konami::SCC &scc) :
|
|
|
|
slot_(slot), scc_(scc) {}
|
2018-01-05 03:18:18 +00:00
|
|
|
|
2020-01-24 03:57:51 +00:00
|
|
|
void write(uint16_t address, uint8_t value, bool pc_is_outside_bios) final {
|
2018-01-05 03:18:18 +00:00
|
|
|
switch(address >> 11) {
|
2018-01-23 02:50:56 +00:00
|
|
|
default:
|
2018-02-10 22:11:16 +00:00
|
|
|
if(pc_is_outside_bios) confidence_counter_.add_miss();
|
2018-01-23 02:50:56 +00:00
|
|
|
break;
|
2018-01-05 03:18:18 +00:00
|
|
|
case 0x0a:
|
2018-02-12 01:32:45 +00:00
|
|
|
if(pc_is_outside_bios) {
|
|
|
|
if(address == 0x5000) confidence_counter_.add_hit(); else confidence_counter_.add_equivocal();
|
|
|
|
}
|
2023-01-16 03:51:17 +00:00
|
|
|
slot_.map(value * 0x2000, 0x4000, 0x2000);
|
2018-01-05 03:18:18 +00:00
|
|
|
break;
|
|
|
|
case 0x0e:
|
2018-02-12 01:32:45 +00:00
|
|
|
if(pc_is_outside_bios) {
|
|
|
|
if(address == 0x7000) confidence_counter_.add_hit(); else confidence_counter_.add_equivocal();
|
|
|
|
}
|
2023-01-16 03:51:17 +00:00
|
|
|
slot_.map(value * 0x2000, 0x6000, 0x2000);
|
2018-01-05 03:18:18 +00:00
|
|
|
break;
|
|
|
|
case 0x12:
|
2018-02-12 01:32:45 +00:00
|
|
|
if(pc_is_outside_bios) {
|
|
|
|
if(address == 0x9000) confidence_counter_.add_hit(); else confidence_counter_.add_equivocal();
|
|
|
|
}
|
2018-01-07 01:15:55 +00:00
|
|
|
if((value&0x3f) == 0x3f) {
|
|
|
|
scc_is_visible_ = true;
|
2023-01-17 00:52:40 +00:00
|
|
|
slot_.map_handler(0x8000, 0x2000);
|
2018-01-07 01:15:55 +00:00
|
|
|
} else {
|
|
|
|
scc_is_visible_ = false;
|
2023-01-16 03:51:17 +00:00
|
|
|
slot_.map(value * 0x2000, 0x8000, 0x2000);
|
2018-01-07 01:15:55 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 0x13:
|
2018-01-23 02:50:56 +00:00
|
|
|
if(scc_is_visible_) {
|
2018-02-10 22:11:16 +00:00
|
|
|
if(pc_is_outside_bios) confidence_counter_.add_hit();
|
2018-01-23 02:50:56 +00:00
|
|
|
scc_.write(address, value);
|
|
|
|
} else {
|
2018-02-10 22:11:16 +00:00
|
|
|
if(pc_is_outside_bios) confidence_counter_.add_miss();
|
2018-01-23 02:50:56 +00:00
|
|
|
}
|
2018-01-05 03:18:18 +00:00
|
|
|
break;
|
|
|
|
case 0x16:
|
2018-02-12 01:32:45 +00:00
|
|
|
if(pc_is_outside_bios) {
|
|
|
|
if(address == 0xb000) confidence_counter_.add_hit(); else confidence_counter_.add_equivocal();
|
|
|
|
}
|
2023-01-16 03:51:17 +00:00
|
|
|
slot_.map(value * 0x2000, 0xa000, 0x2000);
|
2018-01-05 03:18:18 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-24 03:57:51 +00:00
|
|
|
uint8_t read(uint16_t address) final {
|
2018-01-07 01:15:55 +00:00
|
|
|
if(scc_is_visible_ && address >= 0x9800 && address < 0xa000) {
|
2018-01-23 02:50:56 +00:00
|
|
|
confidence_counter_.add_hit();
|
2018-01-07 01:15:55 +00:00
|
|
|
return scc_.read(address);
|
|
|
|
}
|
2018-01-23 02:50:56 +00:00
|
|
|
confidence_counter_.add_miss();
|
2018-01-07 01:15:55 +00:00
|
|
|
return 0xff;
|
|
|
|
}
|
|
|
|
|
2020-01-24 03:57:51 +00:00
|
|
|
virtual std::string debug_type() final {
|
2019-03-02 23:07:05 +00:00
|
|
|
return "KSCC";
|
2018-02-01 12:53:52 +00:00
|
|
|
}
|
|
|
|
|
2018-01-05 03:18:18 +00:00
|
|
|
private:
|
2023-01-13 04:01:11 +00:00
|
|
|
MSX::MemorySlot &slot_;
|
2018-01-07 01:15:55 +00:00
|
|
|
Konami::SCC &scc_;
|
|
|
|
bool scc_is_visible_ = false;
|
2018-01-05 03:18:18 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|