Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
alexbevi
GitHub Repository: alexbevi/BizHawk
Path: blob/master/libgambatte/src/mem/memptrs.cpp
2 views
1
/***************************************************************************
2
* Copyright (C) 2007-2010 by Sindre AamÄs *
3
* [email protected] *
4
* *
5
* This program is free software; you can redistribute it and/or modify *
6
* it under the terms of the GNU General Public License version 2 as *
7
* published by the Free Software Foundation. *
8
* *
9
* This program is distributed in the hope that it will be useful, *
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12
* GNU General Public License version 2 for more details. *
13
* *
14
* You should have received a copy of the GNU General Public License *
15
* version 2 along with this program; if not, write to the *
16
* Free Software Foundation, Inc., *
17
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
18
***************************************************************************/
19
#include "memptrs.h"
20
#include <algorithm>
21
#include <cstring>
22
23
namespace gambatte {
24
25
MemPtrs::MemPtrs()
26
: rmem_(), wmem_(), romdata_(), wramdata_(), vrambankptr_(0), rsrambankptr_(0),
27
wsrambankptr_(0), memchunk_(0), rambankdata_(0), wramdataend_(0), oamDmaSrc_(OAM_DMA_SRC_OFF),
28
memchunk_len(0)
29
{
30
}
31
32
MemPtrs::~MemPtrs() {
33
delete []memchunk_;
34
}
35
36
void MemPtrs::reset(const unsigned rombanks, const unsigned rambanks, const unsigned wrambanks) {
37
delete []memchunk_;
38
memchunk_len = 0x4000 + rombanks * 0x4000ul + 0x4000 + rambanks * 0x2000ul + wrambanks * 0x1000ul + 0x4000;
39
memchunk_ = new unsigned char[memchunk_len];
40
41
romdata_[0] = romdata();
42
rambankdata_ = romdata_[0] + rombanks * 0x4000ul + 0x4000;
43
wramdata_[0] = rambankdata_ + rambanks * 0x2000ul;
44
wramdataend_ = wramdata_[0] + wrambanks * 0x1000ul;
45
46
std::memset(rdisabledRamw(), 0xFF, 0x2000);
47
48
oamDmaSrc_ = OAM_DMA_SRC_OFF;
49
rmem_[0x3] = rmem_[0x2] = rmem_[0x1] = rmem_[0x0] = romdata_[0];
50
rmem_[0xC] = wmem_[0xC] = wramdata_[0] - 0xC000;
51
rmem_[0xE] = wmem_[0xE] = wramdata_[0] - 0xE000;
52
setRombank(1);
53
setRambank(0, 0);
54
setVrambank(0);
55
setWrambank(1);
56
57
// we save only the ram areas
58
memchunk_saveoffs = vramdata() - memchunk_;
59
memchunk_savelen = wramdataend() - memchunk_ - memchunk_saveoffs;
60
}
61
62
void MemPtrs::setRombank0(const unsigned bank) {
63
romdata_[0] = romdata() + bank * 0x4000ul;
64
rmem_[0x3] = rmem_[0x2] = rmem_[0x1] = rmem_[0x0] = romdata_[0];
65
disconnectOamDmaAreas();
66
}
67
68
void MemPtrs::setRombank(const unsigned bank) {
69
romdata_[1] = romdata() + bank * 0x4000ul - 0x4000;
70
rmem_[0x7] = rmem_[0x6] = rmem_[0x5] = rmem_[0x4] = romdata_[1];
71
disconnectOamDmaAreas();
72
}
73
74
void MemPtrs::setRambank(const unsigned flags, const unsigned rambank) {
75
unsigned char *const srambankptr = flags & RTC_EN
76
? 0
77
: (rambankdata() != rambankdataend()
78
? rambankdata_ + rambank * 0x2000ul - 0xA000 : wdisabledRam() - 0xA000);
79
80
rsrambankptr_ = (flags & READ_EN) && srambankptr != wdisabledRam() - 0xA000 ? srambankptr : rdisabledRamw() - 0xA000;
81
wsrambankptr_ = flags & WRITE_EN ? srambankptr : wdisabledRam() - 0xA000;
82
rmem_[0xB] = rmem_[0xA] = rsrambankptr_;
83
wmem_[0xB] = wmem_[0xA] = wsrambankptr_;
84
disconnectOamDmaAreas();
85
}
86
87
void MemPtrs::setWrambank(const unsigned bank) {
88
wramdata_[1] = wramdata_[0] + ((bank & 0x07) ? (bank & 0x07) : 1) * 0x1000;
89
rmem_[0xD] = wmem_[0xD] = wramdata_[1] - 0xD000;
90
disconnectOamDmaAreas();
91
}
92
93
void MemPtrs::setOamDmaSrc(const OamDmaSrc oamDmaSrc) {
94
rmem_[0x3] = rmem_[0x2] = rmem_[0x1] = rmem_[0x0] = romdata_[0];
95
rmem_[0x7] = rmem_[0x6] = rmem_[0x5] = rmem_[0x4] = romdata_[1];
96
rmem_[0xB] = rmem_[0xA] = rsrambankptr_;
97
wmem_[0xB] = wmem_[0xA] = wsrambankptr_;
98
rmem_[0xC] = wmem_[0xC] = wramdata_[0] - 0xC000;
99
rmem_[0xD] = wmem_[0xD] = wramdata_[1] - 0xD000;
100
rmem_[0xE] = wmem_[0xE] = wramdata_[0] - 0xE000;
101
102
oamDmaSrc_ = oamDmaSrc;
103
disconnectOamDmaAreas();
104
}
105
106
void MemPtrs::disconnectOamDmaAreas() {
107
if (isCgb(*this)) {
108
switch (oamDmaSrc_) {
109
case OAM_DMA_SRC_ROM: // fall through
110
case OAM_DMA_SRC_SRAM:
111
case OAM_DMA_SRC_INVALID:
112
std::fill(rmem_, rmem_ + 8, static_cast<unsigned char *>(0));
113
rmem_[0xB] = rmem_[0xA] = 0;
114
wmem_[0xB] = wmem_[0xA] = 0;
115
break;
116
case OAM_DMA_SRC_VRAM:
117
break;
118
case OAM_DMA_SRC_WRAM:
119
rmem_[0xE] = rmem_[0xD] = rmem_[0xC] = 0;
120
wmem_[0xE] = wmem_[0xD] = wmem_[0xC] = 0;
121
break;
122
case OAM_DMA_SRC_OFF:
123
break;
124
}
125
} else {
126
switch (oamDmaSrc_) {
127
case OAM_DMA_SRC_ROM: // fall through
128
case OAM_DMA_SRC_SRAM:
129
case OAM_DMA_SRC_WRAM:
130
case OAM_DMA_SRC_INVALID:
131
std::fill(rmem_, rmem_ + 8, static_cast<unsigned char *>(0));
132
rmem_[0xB] = rmem_[0xA] = 0;
133
wmem_[0xB] = wmem_[0xA] = 0;
134
rmem_[0xE] = rmem_[0xD] = rmem_[0xC] = 0;
135
wmem_[0xE] = wmem_[0xD] = wmem_[0xC] = 0;
136
break;
137
case OAM_DMA_SRC_VRAM:
138
break;
139
case OAM_DMA_SRC_OFF:
140
break;
141
}
142
}
143
}
144
145
// all pointers here are relative to memchunk_
146
#define MSS(a) RSS(a,memchunk_)
147
#define MSL(a) RSL(a,memchunk_)
148
149
SYNCFUNC(MemPtrs)
150
{
151
/*
152
int memchunk_len_old = memchunk_len;
153
int memchunk_saveoffs_old = memchunk_saveoffs;
154
int memchunk_savelen_old = memchunk_savelen;
155
*/
156
157
NSS(memchunk_len);
158
NSS(memchunk_saveoffs);
159
NSS(memchunk_savelen);
160
161
/*
162
if (isReader)
163
{
164
if (memchunk_len != memchunk_len_old || memchunk_saveoffs != memchunk_saveoffs_old || memchunk_savelen != memchunk_savelen_old)
165
__debugbreak();
166
}
167
*/
168
169
PSS(memchunk_ + memchunk_saveoffs, memchunk_savelen);
170
171
MSS(rmem_[0x0]);
172
MSS(wmem_[0x0]);
173
MSS(rmem_[0x1]);
174
MSS(wmem_[0x1]);
175
MSS(rmem_[0x2]);
176
MSS(wmem_[0x2]);
177
MSS(rmem_[0x3]);
178
MSS(wmem_[0x3]);
179
MSS(rmem_[0x4]);
180
MSS(wmem_[0x4]);
181
MSS(rmem_[0x5]);
182
MSS(wmem_[0x5]);
183
MSS(rmem_[0x6]);
184
MSS(wmem_[0x6]);
185
MSS(rmem_[0x7]);
186
MSS(wmem_[0x7]);
187
MSS(rmem_[0x8]);
188
MSS(wmem_[0x8]);
189
MSS(rmem_[0x9]);
190
MSS(wmem_[0x9]);
191
MSS(rmem_[0xa]);
192
MSS(wmem_[0xa]);
193
MSS(rmem_[0xb]);
194
MSS(wmem_[0xb]);
195
MSS(rmem_[0xc]);
196
MSS(wmem_[0xc]);
197
MSS(rmem_[0xd]);
198
MSS(wmem_[0xd]);
199
MSS(rmem_[0xe]);
200
MSS(wmem_[0xe]);
201
MSS(rmem_[0xf]);
202
MSS(wmem_[0xf]);
203
//for (int i = 0; i < 0x10; i++)
204
//{
205
// MSS(rmem_[i]);
206
// MSS(wmem_[i]);
207
//}
208
MSS(romdata_[0]);
209
MSS(romdata_[1]);
210
MSS(wramdata_[0]);
211
MSS(wramdata_[1]);
212
MSS(vrambankptr_);
213
MSS(rsrambankptr_);
214
MSS(wsrambankptr_);
215
MSS(rambankdata_);
216
MSS(wramdataend_);
217
NSS(oamDmaSrc_);
218
}
219
220
}
221
222