libsidplayfp 3.0.0
c64cia.h
1/*
2 * This file is part of libsidplayfp, a SID player engine.
3 *
4 * Copyright 2011-2021 Leandro Nini <drfiemost@users.sourceforge.net>
5 * Copyright 2007-2010 Antti Lankila
6 * Copyright 2001 Simon White
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
21 */
22
23#ifndef C64CIA_H
24#define C64CIA_H
25
26// The CIA emulations are very generic and here we need to effectively
27// wire them into the computer (like adding a chip to a PCB).
28
29#include "Banks/Bank.h"
30#include "c64/c64env.h"
31#include "sidendian.h"
32#include "CIA/mos652x.h"
33
34#include "sidcxx11.h"
35
36namespace libsidplayfp
37{
38
46class c64cia1 final : public MOS652X, public Bank
47{
48private:
49 c64env &m_env;
50 uint_least16_t last_ta;
51
52protected:
53 void interrupt(bool state) override
54 {
55 m_env.interruptIRQ(state);
56 }
57
58 void portB() override
59 {
60 const uint8_t pb = prb | ~ddrb;
61 // We should call adjustDataPort here
62 // but we're only interested in bit 4
63 m_env.lightpen(pb & 0x10);
64 }
65
66public:
67 explicit c64cia1(c64env &env) :
68 MOS652X(env.scheduler()),
69 m_env(env) {
70 reset();
71 }
72
73 void poke(uint_least16_t address, uint8_t value) override
74 {
75 const uint8_t addr = endian_16lo8(address);
76 write(addr, value);
77
78 // Save the value written to Timer A
79 if ((addr == 0x04) || (addr == 0x05))
80 {
81 if (timerA.getTimer() != 0)
82 last_ta = timerA.getTimer();
83 }
84 }
85
86 uint8_t peek(uint_least16_t address) override
87 {
88 return read(endian_16lo8(address));
89 }
90
91 void reset() override
92 {
93 last_ta = 0;
95 }
96
97 uint_least16_t getTimerA() const { return last_ta; }
98};
99
107class c64cia2 : public MOS652X, public Bank
108{
109private:
110 c64env &m_env;
111
112protected:
113 void interrupt(bool state) override
114 {
115 if (state)
116 m_env.interruptNMI();
117 }
118
119public:
120 explicit c64cia2(c64env &env) :
121 MOS652X(env.scheduler()),
122 m_env(env) {
123 reset();
124 }
125
126 void poke(uint_least16_t address, uint8_t value) override
127 {
128 write(endian_16lo8(address), value);
129 }
130
131 uint8_t peek(uint_least16_t address) override
132 {
133 return read(endian_16lo8(address));
134 }
135};
136
137}
138
139#endif // C64CIA_H
Definition Bank.h:36
Definition mos652x.h:154
TimerA timerA
Timers A and B.
Definition mos652x.h:186
void write(uint_least8_t addr, uint8_t data)
Definition mos652x.cpp:222
MOS652X(EventScheduler &scheduler)
Definition mos652x.cpp:122
virtual void reset()
Definition mos652x.cpp:147
uint8_t read(uint_least8_t addr)
Definition mos652x.cpp:183
void reset() override
Definition c64cia.h:91
void poke(uint_least16_t address, uint8_t value) override
Definition c64cia.h:73
void interrupt(bool state) override
Definition c64cia.h:53
uint8_t peek(uint_least16_t address) override
Definition c64cia.h:86
Definition c64cia.h:108
void poke(uint_least16_t address, uint8_t value) override
Definition c64cia.h:126
uint8_t peek(uint_least16_t address) override
Definition c64cia.h:131
void interrupt(bool state) override
Definition c64cia.h:113
Definition c64env.h:41