mirror of https://github.com/bsnes-emu/bsnes.git
Update to v074r05 release.
byuu says: Oh good, that turned out to be a lot easier than I expected. Almost all of the work was already done yesterday in porting the SA-1 over to a static map.
This commit is contained in:
parent
a937f9b79b
commit
ea077a7d96
|
@ -38,7 +38,7 @@ void Cartridge::load(Mode cartridge_mode, const lstring &xml_list) {
|
||||||
has_serial = false;
|
has_serial = false;
|
||||||
|
|
||||||
parse_xml(xml_list);
|
parse_xml(xml_list);
|
||||||
print(xml_list[0], "\n\n");
|
//print(xml_list[0], "\n\n");
|
||||||
|
|
||||||
if(ram_size > 0) {
|
if(ram_size > 0) {
|
||||||
memory::cartram.map(allocate<uint8_t>(ram_size, 0xff), ram_size);
|
memory::cartram.map(allocate<uint8_t>(ram_size, 0xff), ram_size);
|
||||||
|
|
|
@ -1,8 +1,5 @@
|
||||||
#ifdef SA1_CPP
|
#ifdef SA1_CPP
|
||||||
|
|
||||||
VBRBus vbrbus;
|
|
||||||
SA1Bus sa1bus;
|
|
||||||
|
|
||||||
namespace memory {
|
namespace memory {
|
||||||
StaticRAM iram(2048);
|
StaticRAM iram(2048);
|
||||||
//accessed by:
|
//accessed by:
|
||||||
|
@ -13,46 +10,6 @@ namespace memory {
|
||||||
BitmapRAM bitmapram; //SA-1
|
BitmapRAM bitmapram; //SA-1
|
||||||
}
|
}
|
||||||
|
|
||||||
//$230c (VDPL), $230d (VDPH) use this bus to read variable-length data.
|
|
||||||
//this is used both to keep VBR-reads from accessing MMIO registers, and
|
|
||||||
//to avoid syncing the S-CPU and SA-1*; as both chips are able to access
|
|
||||||
//these ports.
|
|
||||||
//(* eg, memory::cartram is used directly, as memory::sa1bwram syncs to the S-CPU)
|
|
||||||
void VBRBus::init() {
|
|
||||||
map(MapMode::Direct, 0x00, 0x3f, 0x8000, 0xffff, { &SA1::mmc_read, &sa1 }, { &SA1::mmc_write, &sa1 });
|
|
||||||
map(MapMode::Direct, 0x80, 0xbf, 0x8000, 0xffff, { &SA1::mmc_read, &sa1 }, { &SA1::mmc_write, &sa1 });
|
|
||||||
map(MapMode::Direct, 0xc0, 0xff, 0x0000, 0xffff, { &SA1::mmc_read, &sa1 }, { &SA1::mmc_write, &sa1 });
|
|
||||||
|
|
||||||
map(MapMode::Linear, 0x00, 0x3f, 0x6000, 0x7fff, { &MappedRAM::read, &memory::cartram }, { &MappedRAM::write, &memory::cartram }, 0, memory::cartram.size());
|
|
||||||
map(MapMode::Linear, 0x80, 0xbf, 0x6000, 0x7fff, { &MappedRAM::read, &memory::cartram }, { &MappedRAM::write, &memory::cartram }, 0, memory::cartram.size());
|
|
||||||
map(MapMode::Linear, 0x40, 0x4f, 0x0000, 0xffff, { &MappedRAM::read, &memory::cartram }, { &MappedRAM::write, &memory::cartram }, 0, memory::cartram.size());
|
|
||||||
|
|
||||||
map(MapMode::Linear, 0x00, 0x3f, 0x0000, 0x07ff, { &StaticRAM::read, &memory::iram }, { &StaticRAM::write, &memory::iram }, 0, 2048);
|
|
||||||
map(MapMode::Linear, 0x00, 0x3f, 0x3000, 0x37ff, { &StaticRAM::read, &memory::iram }, { &StaticRAM::write, &memory::iram }, 0, 2048);
|
|
||||||
map(MapMode::Linear, 0x80, 0xbf, 0x0000, 0x07ff, { &StaticRAM::read, &memory::iram }, { &StaticRAM::write, &memory::iram }, 0, 2048);
|
|
||||||
map(MapMode::Linear, 0x80, 0xbf, 0x3000, 0x37ff, { &StaticRAM::read, &memory::iram }, { &StaticRAM::write, &memory::iram }, 0, 2048);
|
|
||||||
}
|
|
||||||
|
|
||||||
void SA1Bus::init() {
|
|
||||||
map(MapMode::Direct, 0x00, 0x3f, 0x2200, 0x23ff, { &SA1::mmio_read, &sa1 }, { &SA1::mmio_write, &sa1 });
|
|
||||||
map(MapMode::Direct, 0x80, 0xbf, 0x2200, 0x23ff, { &SA1::mmio_read, &sa1 }, { &SA1::mmio_write, &sa1 });
|
|
||||||
|
|
||||||
map(MapMode::Direct, 0x00, 0x3f, 0x8000, 0xffff, { &SA1::mmc_read, &sa1 }, { &SA1::mmc_write, &sa1 });
|
|
||||||
map(MapMode::Direct, 0x80, 0xbf, 0x8000, 0xffff, { &SA1::mmc_read, &sa1 }, { &SA1::mmc_write, &sa1 });
|
|
||||||
map(MapMode::Direct, 0xc0, 0xff, 0x0000, 0xffff, { &SA1::mmc_read, &sa1 }, { &SA1::mmc_write, &sa1 });
|
|
||||||
|
|
||||||
map(MapMode::Linear, 0x00, 0x3f, 0x6000, 0x7fff, { &SA1::mmc_sa1_read, &sa1 }, { &SA1::mmc_sa1_write, &sa1 });
|
|
||||||
map(MapMode::Linear, 0x80, 0xbf, 0x6000, 0x7fff, { &SA1::mmc_sa1_read, &sa1 }, { &SA1::mmc_sa1_write, &sa1 });
|
|
||||||
|
|
||||||
map(MapMode::Linear, 0x00, 0x3f, 0x0000, 0x07ff, { &SA1IRAM::read, &memory::sa1iram }, { &SA1IRAM::write, &memory::sa1iram }, 0, 2048);
|
|
||||||
map(MapMode::Linear, 0x00, 0x3f, 0x3000, 0x37ff, { &SA1IRAM::read, &memory::sa1iram }, { &SA1IRAM::write, &memory::sa1iram }, 0, 2048);
|
|
||||||
map(MapMode::Linear, 0x80, 0xbf, 0x0000, 0x07ff, { &SA1IRAM::read, &memory::sa1iram }, { &SA1IRAM::write, &memory::sa1iram }, 0, 2048);
|
|
||||||
map(MapMode::Linear, 0x80, 0xbf, 0x3000, 0x37ff, { &SA1IRAM::read, &memory::sa1iram }, { &SA1IRAM::write, &memory::sa1iram }, 0, 2048);
|
|
||||||
|
|
||||||
map(MapMode::Linear, 0x40, 0x4f, 0x0000, 0xffff, { &SA1BWRAM::read, &memory::sa1bwram }, { &SA1BWRAM::write, &memory::sa1bwram }, 0, memory::sa1bwram.size());
|
|
||||||
map(MapMode::Linear, 0x60, 0x6f, 0x0000, 0xffff, { &BitmapRAM::read, &memory::bitmapram }, { &BitmapRAM::write, &memory::bitmapram }, 0, memory::bitmapram.size());
|
|
||||||
}
|
|
||||||
|
|
||||||
//=======
|
//=======
|
||||||
//SA1IRAM
|
//SA1IRAM
|
||||||
//=======
|
//=======
|
||||||
|
|
|
@ -1,11 +1,3 @@
|
||||||
struct VBRBus : Bus {
|
|
||||||
void init();
|
|
||||||
};
|
|
||||||
|
|
||||||
struct SA1Bus : Bus {
|
|
||||||
void init();
|
|
||||||
};
|
|
||||||
|
|
||||||
struct CPUIRAM : Memory {
|
struct CPUIRAM : Memory {
|
||||||
unsigned size() const;
|
unsigned size() const;
|
||||||
alwaysinline uint8 read(unsigned);
|
alwaysinline uint8 read(unsigned);
|
||||||
|
|
|
@ -17,13 +17,13 @@ void SA1::dma_normal() {
|
||||||
switch(mmio.sd) {
|
switch(mmio.sd) {
|
||||||
case DMA::SourceROM: {
|
case DMA::SourceROM: {
|
||||||
if((dsa & 0x408000) == 0x008000 || (dsa & 0xc00000) == 0xc00000) {
|
if((dsa & 0x408000) == 0x008000 || (dsa & 0xc00000) == 0xc00000) {
|
||||||
data = sa1bus.read(dsa);
|
data = bus_read(dsa);
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case DMA::SourceBWRAM: {
|
case DMA::SourceBWRAM: {
|
||||||
if((dsa & 0x40e000) == 0x006000 || (dsa & 0xf00000) == 0x400000) {
|
if((dsa & 0x40e000) == 0x006000 || (dsa & 0xf00000) == 0x400000) {
|
||||||
data = sa1bus.read(dsa);
|
data = bus_read(dsa);
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ void SA1::dma_normal() {
|
||||||
switch(mmio.dd) {
|
switch(mmio.dd) {
|
||||||
case DMA::DestBWRAM: {
|
case DMA::DestBWRAM: {
|
||||||
if((dda & 0x40e000) == 0x006000 || (dda & 0xf00000) == 0x400000) {
|
if((dda & 0x40e000) == 0x006000 || (dda & 0xf00000) == 0x400000) {
|
||||||
sa1bus.write(dda, data);
|
bus_write(dda, data);
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,96 @@
|
||||||
#ifdef SA1_CPP
|
#ifdef SA1_CPP
|
||||||
|
|
||||||
|
uint8 SA1::bus_read(unsigned addr) {
|
||||||
|
if((addr & 0x40fe00) == 0x002200) { //$00-3f|80-bf:2200-23ff
|
||||||
|
return mmio_read(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x408000) == 0x008000) { //$00-3f|80-bf:8000-ffff
|
||||||
|
return mmc_read(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xc00000) == 0xc00000) { //$c0-ff:0000-ffff
|
||||||
|
return mmc_read(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40e000) == 0x006000) { //$00-3f|80-bf:6000-7fff
|
||||||
|
return mmc_sa1_read(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40f800) == 0x000000) { //$00-3f|80-bf:0000-07ff
|
||||||
|
return memory::iram.read(addr & 2047);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40f800) == 0x003000) { //$00-3f|80-bf:3000-37ff
|
||||||
|
return memory::iram.read(addr & 2047);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xf00000) == 0x400000) { //$40-4f:0000-ffff
|
||||||
|
return memory::sa1bwram.read(addr & (memory::sa1bwram.size() - 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xf00000) == 0x600000) { //$60-6f:0000-ffff
|
||||||
|
return memory::bitmapram.read(addr & (memory::bitmapram.size() - 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SA1::bus_write(unsigned addr, uint8 data) {
|
||||||
|
if((addr & 0x40fe00) == 0x002200) { //$00-3f|80-bf:2200-23ff
|
||||||
|
return mmio_write(addr, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40e000) == 0x006000) { //$00-3f|80-bf:6000-7fff
|
||||||
|
return mmc_sa1_write(addr, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40f800) == 0x000000) { //$00-3f|80-bf:0000-07ff
|
||||||
|
return memory::iram.write(addr & 2047, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40f800) == 0x003000) { //$00-3f|80-bf:3000-37ff
|
||||||
|
return memory::iram.write(addr & 2047, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xf00000) == 0x400000) { //$40-4f:0000-ffff
|
||||||
|
return memory::sa1bwram.write(addr & (memory::sa1bwram.size() - 1), data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xf00000) == 0x600000) { //$60-6f:0000-ffff
|
||||||
|
return memory::bitmapram.write(addr & (memory::bitmapram.size() - 1), data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//$230c (VDPL), $230d (VDPH) use this bus to read variable-length data.
|
||||||
|
//this is used both to keep VBR-reads from accessing MMIO registers, and
|
||||||
|
//to avoid syncing the S-CPU and SA-1*; as both chips are able to access
|
||||||
|
//these ports.
|
||||||
|
//(* eg, memory::cartram is used directly, as memory::sa1bwram syncs to the S-CPU)
|
||||||
|
uint8 SA1::vbr_read(unsigned addr) {
|
||||||
|
if((addr & 0x408000) == 0x008000) { //$00-3f|80-bf:8000-ffff
|
||||||
|
return mmc_read(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xc00000) == 0xc00000) { //$c0-ff:0000-ffff
|
||||||
|
return mmc_read(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40e000) == 0x006000) { //$00-3f|80-bf:6000-7fff
|
||||||
|
return memory::cartram.read(addr & (memory::cartram.size() - 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0xf00000) == 0x400000) { //$40-4f:0000-ffff
|
||||||
|
return memory::cartram.read(addr & (memory::cartram.size() - 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40f800) == 0x000000) { //$00-3f|80-bf:0000-07ff
|
||||||
|
return memory::iram.read(addr & 2047);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((addr & 0x40f800) == 0x003000) { //$00-3f|80-bf:3000-37ff
|
||||||
|
return memory::iram.read(addr & 0x2047);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//ROM, I-RAM and MMIO registers are accessed at ~10.74MHz (2 clock ticks)
|
//ROM, I-RAM and MMIO registers are accessed at ~10.74MHz (2 clock ticks)
|
||||||
//BW-RAM is accessed at ~5.37MHz (4 clock ticks)
|
//BW-RAM is accessed at ~5.37MHz (4 clock ticks)
|
||||||
//tick() == 2 clock ticks
|
//tick() == 2 clock ticks
|
||||||
|
@ -12,13 +103,13 @@ void SA1::op_io() {
|
||||||
uint8 SA1::op_read(unsigned addr) {
|
uint8 SA1::op_read(unsigned addr) {
|
||||||
tick();
|
tick();
|
||||||
if(((addr & 0x40e000) == 0x006000) || ((addr & 0xd00000) == 0x400000)) tick();
|
if(((addr & 0x40e000) == 0x006000) || ((addr & 0xd00000) == 0x400000)) tick();
|
||||||
return sa1bus.read(addr);
|
return bus_read(addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SA1::op_write(unsigned addr, uint8 data) {
|
void SA1::op_write(unsigned addr, uint8 data) {
|
||||||
tick();
|
tick();
|
||||||
if(((addr & 0x40e000) == 0x006000) || ((addr & 0xd00000) == 0x400000)) tick();
|
if(((addr & 0x40e000) == 0x006000) || ((addr & 0xd00000) == 0x400000)) tick();
|
||||||
sa1bus.write(addr, data);
|
bus_write(addr, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8 SA1::mmc_read(unsigned addr) {
|
uint8 SA1::mmc_read(unsigned addr) {
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
uint8 bus_read(unsigned addr);
|
||||||
|
void bus_write(unsigned addr, uint8 data);
|
||||||
|
uint8 vbr_read(unsigned addr);
|
||||||
|
|
||||||
alwaysinline void op_io();
|
alwaysinline void op_io();
|
||||||
alwaysinline uint8 op_read(unsigned addr);
|
alwaysinline uint8 op_read(unsigned addr);
|
||||||
alwaysinline void op_write(unsigned addr, uint8 data);
|
alwaysinline void op_write(unsigned addr, uint8 data);
|
||||||
|
|
|
@ -414,18 +414,18 @@ uint8 SA1::mmio_r230b() { return mmio.overflow << 7; }
|
||||||
|
|
||||||
//(VDPL) variable-length data read port low
|
//(VDPL) variable-length data read port low
|
||||||
uint8 SA1::mmio_r230c() {
|
uint8 SA1::mmio_r230c() {
|
||||||
uint32 data = (vbrbus.read(mmio.va + 0) << 0)
|
uint32 data = (vbr_read(mmio.va + 0) << 0)
|
||||||
| (vbrbus.read(mmio.va + 1) << 8)
|
| (vbr_read(mmio.va + 1) << 8)
|
||||||
| (vbrbus.read(mmio.va + 2) << 16);
|
| (vbr_read(mmio.va + 2) << 16);
|
||||||
data >>= mmio.vbit;
|
data >>= mmio.vbit;
|
||||||
return data >> 0;
|
return data >> 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//(VDPH) variable-length data read port high
|
//(VDPH) variable-length data read port high
|
||||||
uint8 SA1::mmio_r230d() {
|
uint8 SA1::mmio_r230d() {
|
||||||
uint32 data = (vbrbus.read(mmio.va + 0) << 0)
|
uint32 data = (vbr_read(mmio.va + 0) << 0)
|
||||||
| (vbrbus.read(mmio.va + 1) << 8)
|
| (vbr_read(mmio.va + 1) << 8)
|
||||||
| (vbrbus.read(mmio.va + 2) << 16);
|
| (vbr_read(mmio.va + 2) << 16);
|
||||||
data >>= mmio.vbit;
|
data >>= mmio.vbit;
|
||||||
|
|
||||||
if(mmio.hl == 1) {
|
if(mmio.hl == 1) {
|
||||||
|
|
|
@ -129,8 +129,6 @@ void SA1::power() {
|
||||||
|
|
||||||
void SA1::reset() {
|
void SA1::reset() {
|
||||||
create(SA1::Enter, system.cpu_frequency());
|
create(SA1::Enter, system.cpu_frequency());
|
||||||
vbrbus.init();
|
|
||||||
sa1bus.init();
|
|
||||||
|
|
||||||
memory::cc1bwram.dma = false;
|
memory::cc1bwram.dma = false;
|
||||||
for(unsigned addr = 0; addr < memory::iram.size(); addr++) {
|
for(unsigned addr = 0; addr < memory::iram.size(); addr++) {
|
||||||
|
|
|
@ -36,4 +36,3 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
extern SA1 sa1;
|
extern SA1 sa1;
|
||||||
extern SA1Bus sa1bus;
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
namespace SNES {
|
namespace SNES {
|
||||||
namespace Info {
|
namespace Info {
|
||||||
static const char Name[] = "bsnes";
|
static const char Name[] = "bsnes";
|
||||||
static const char Version[] = "074.04";
|
static const char Version[] = "074.05";
|
||||||
static const unsigned SerializerVersion = 17;
|
static const unsigned SerializerVersion = 17;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue