Update to v082r33 release.
byuu says:
Added MMC2, MMC4, VRC4, VRC7 (no audio.)
Split NES audio code up into individual modules.
Fixed libsnes to compile: Themaister, can you please test to make sure
it works? I don't have a libsnes client on my work PC to test it.
Added about / license information to bottom of advanced settings screen
for now (better than nothing, I guess.)
Blocked PPU reads/writes while rendering for now, easier than coming up
with a bus address locking thing :/
I can't seem to fix MMC5 graphics during the intro to Uchuu Keibitai.
Without that, trying to implement vertical-split screen mode doesn't
make sense.
So as far as special audio chips go ...
* VRC6 is completed
* Sunsoft 5B has everything the only game to use it uses, but there are
more unused channels I'd like to support anyway (they aren't
documented, though.)
* MMC5 audio unsupported for now
* VRC7 audio unsupported, probably for a long time (hardest audio driver
of all. More complex than core NES APU.)
* audio PCM games (Moero Pro Yakyuu!) I probably won't ever support
(they require external WAV packs.)
2011-10-12 12:03:58 +00:00
|
|
|
//MMC2
|
|
|
|
|
|
|
|
struct NES_PxROM : Board {
|
|
|
|
|
|
|
|
enum Revision : unsigned {
|
|
|
|
PEEOROM,
|
|
|
|
PNROM,
|
|
|
|
} revision;
|
|
|
|
|
|
|
|
uint4 prg_bank;
|
|
|
|
uint5 chr_bank[2][2];
|
|
|
|
bool mirror;
|
|
|
|
bool latch[2];
|
|
|
|
|
|
|
|
uint8 prg_read(unsigned addr) {
|
|
|
|
if(addr < 0x6000) return cpu.mdr();
|
|
|
|
if(addr < 0x8000) return prgram.read(addr);
|
|
|
|
unsigned bank = 0;
|
|
|
|
switch((addr / 0x2000) & 3) {
|
|
|
|
case 0: bank = prg_bank; break;
|
|
|
|
case 1: bank = 0x0d; break;
|
|
|
|
case 2: bank = 0x0e; break;
|
|
|
|
case 3: bank = 0x0f; break;
|
|
|
|
}
|
|
|
|
return prgrom.read((bank * 0x2000) | (addr & 0x1fff));
|
|
|
|
}
|
|
|
|
|
|
|
|
void prg_write(unsigned addr, uint8 data) {
|
|
|
|
if(addr < 0x6000) return;
|
|
|
|
if(addr < 0x8000) return prgram.write(addr, data);
|
|
|
|
|
|
|
|
switch(addr & 0xf000) {
|
|
|
|
case 0xa000: prg_bank = data & 0x0f; break;
|
|
|
|
case 0xb000: chr_bank[0][0] = data & 0x1f; break;
|
|
|
|
case 0xc000: chr_bank[0][1] = data & 0x1f; break;
|
|
|
|
case 0xd000: chr_bank[1][0] = data & 0x1f; break;
|
|
|
|
case 0xe000: chr_bank[1][1] = data & 0x1f; break;
|
|
|
|
case 0xf000: mirror = data & 0x01; break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned ciram_addr(unsigned addr) const {
|
|
|
|
switch(mirror) {
|
|
|
|
case 0: return ((addr & 0x0400) >> 0) | (addr & 0x03ff); //vertical mirroring
|
|
|
|
case 1: return ((addr & 0x0800) >> 1) | (addr & 0x03ff); //horizontal mirroring
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
uint8 chr_read(unsigned addr) {
|
|
|
|
if(addr & 0x2000) return ppu.ciram_read(ciram_addr(addr));
|
|
|
|
bool region = addr & 0x1000;
|
|
|
|
unsigned bank = chr_bank[region][latch[region]];
|
|
|
|
if((addr & 0x0ff8) == 0x0fd8) latch[region] = 0;
|
|
|
|
if((addr & 0x0ff8) == 0x0fe8) latch[region] = 1;
|
|
|
|
return Board::chr_read((bank * 0x1000) | (addr & 0x0fff));
|
|
|
|
}
|
|
|
|
|
|
|
|
void chr_write(unsigned addr, uint8 data) {
|
|
|
|
if(addr & 0x2000) return ppu.ciram_write(ciram_addr(addr), data);
|
|
|
|
bool region = addr & 0x1000;
|
|
|
|
unsigned bank = chr_bank[region][latch[region]];
|
|
|
|
if((addr & 0x0ff8) == 0x0fd8) latch[region] = 0;
|
|
|
|
if((addr & 0x0ff8) == 0x0fe8) latch[region] = 1;
|
|
|
|
return Board::chr_write((bank * 0x1000) | (addr & 0x0fff), data);
|
|
|
|
}
|
|
|
|
|
|
|
|
void power() {
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset() {
|
|
|
|
prg_bank = 0;
|
|
|
|
chr_bank[0][0] = 0;
|
|
|
|
chr_bank[0][1] = 0;
|
|
|
|
chr_bank[1][0] = 0;
|
|
|
|
chr_bank[1][1] = 0;
|
|
|
|
mirror = 0;
|
|
|
|
latch[0] = 0;
|
|
|
|
latch[1] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void serialize(serializer &s) {
|
|
|
|
Board::serialize(s);
|
|
|
|
|
|
|
|
s.integer(prg_bank);
|
|
|
|
s.integer(chr_bank[0][0]);
|
|
|
|
s.integer(chr_bank[0][1]);
|
|
|
|
s.integer(chr_bank[1][0]);
|
|
|
|
s.integer(chr_bank[1][1]);
|
|
|
|
s.integer(mirror);
|
|
|
|
s.array(latch);
|
|
|
|
}
|
|
|
|
|
Update to v091r05 release.
[No prior releases were posted to the WIP thread. -Ed.]
byuu says:
Super Famicom mapping system has been reworked as discussed with the
mask= changes. offset becomes base, mode is gone. Also added support for
comma-separated fields in the address fields, to reduce the number of
map lines needed.
<?xml version="1.0" encoding="UTF-8"?>
<cartridge region="NTSC">
<superfx revision="2">
<rom name="program.rom" size="0x200000"/>
<ram name="save.rwm" size="0x8000"/>
<map id="io" address="00-3f,80-bf:3000-32ff"/>
<map id="rom" address="00-3f:8000-ffff" mask="0x8000"/>
<map id="rom" address="40-5f:0000-ffff"/>
<map id="ram" address="00-3f,80-bf:6000-7fff" size="0x2000"/>
<map id="ram" address="70-71:0000-ffff"/>
</superfx>
</cartridge>
Or in BML:
cartridge region=NTSC
superfx revision=2
rom name=program.rom size=0x200000
ram name=save.rwm size=0x8000
map id=io address=00-3f,80-bf:3000-32ff
map id=rom address=00-3f:8000-ffff mask=0x8000
map id=rom address=40-5f:0000-ffff
map id=ram address=00-3f,80-bf:6000-7fff size=0x2000
map id=ram address=70-71:0000-ffff
As a result of the changes, old mappings will no longer work. The above
XML example will run Super Mario World 2: Yoshi's Island. Otherwise,
you'll have to write your own.
All that's left now is to work some sort of database mapping system in,
so I can start dumping carts en masse.
The NES changes that FitzRoy asked for are mostly in as well.
Also, part of the reason I haven't released a WIP ... but fuck it, I'm
not going to wait forever to post a new WIP.
I've added a skeleton driver to emulate Campus Challenge '92 and
Powerfest '94. There's no actual emulation, except for the stuff I can
glean from looking at the pictures of the board. It has a DSP-1 (so
SR/DR registers), four ROMs that map in and out, RAM, etc.
I've also added preliminary mapping to upload high scores to a website,
but obviously I need the ROMs first.
2012-10-09 08:25:32 +00:00
|
|
|
NES_PxROM(Markup::Node &document) : Board(document) {
|
Update to v082r33 release.
byuu says:
Added MMC2, MMC4, VRC4, VRC7 (no audio.)
Split NES audio code up into individual modules.
Fixed libsnes to compile: Themaister, can you please test to make sure
it works? I don't have a libsnes client on my work PC to test it.
Added about / license information to bottom of advanced settings screen
for now (better than nothing, I guess.)
Blocked PPU reads/writes while rendering for now, easier than coming up
with a bus address locking thing :/
I can't seem to fix MMC5 graphics during the intro to Uchuu Keibitai.
Without that, trying to implement vertical-split screen mode doesn't
make sense.
So as far as special audio chips go ...
* VRC6 is completed
* Sunsoft 5B has everything the only game to use it uses, but there are
more unused channels I'd like to support anyway (they aren't
documented, though.)
* MMC5 audio unsupported for now
* VRC7 audio unsupported, probably for a long time (hardest audio driver
of all. More complex than core NES APU.)
* audio PCM games (Moero Pro Yakyuu!) I probably won't ever support
(they require external WAV packs.)
2011-10-12 12:03:58 +00:00
|
|
|
revision = Revision::PNROM;
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|