mirror of https://github.com/bsnes-emu/bsnes.git
v108.13
* fix CPU DMA regression from higan v106.62 (fixes Battle Grand Prix)
This commit is contained in:
parent
f9ca7a4927
commit
ce3dba130c
|
@ -29,7 +29,7 @@ using namespace nall;
|
||||||
|
|
||||||
namespace Emulator {
|
namespace Emulator {
|
||||||
static const string Name = "bsnes";
|
static const string Name = "bsnes";
|
||||||
static const string Version = "108.12";
|
static const string Version = "108.13";
|
||||||
static const string Author = "byuu";
|
static const string Author = "byuu";
|
||||||
static const string License = "GPLv3";
|
static const string License = "GPLv3";
|
||||||
static const string Website = "https://byuu.org";
|
static const string Website = "https://byuu.org";
|
||||||
|
|
|
@ -40,7 +40,6 @@ struct CPU : Processor::WDC65816, Thread, PPUcounter {
|
||||||
auto writeDMA(uint address, uint8 data) -> void;
|
auto writeDMA(uint address, uint8 data) -> void;
|
||||||
|
|
||||||
//timing.cpp
|
//timing.cpp
|
||||||
inline auto dmaClocks() const -> uint;
|
|
||||||
inline auto dmaCounter() const -> uint;
|
inline auto dmaCounter() const -> uint;
|
||||||
inline auto joypadCounter() const -> uint;
|
inline auto joypadCounter() const -> uint;
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,7 @@ auto CPU::hdmaActive() -> bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
auto CPU::dmaRun() -> void {
|
auto CPU::dmaRun() -> void {
|
||||||
|
counter.dma += 8;
|
||||||
step<8,0>();
|
step<8,0>();
|
||||||
dmaEdge();
|
dmaEdge();
|
||||||
for(auto& channel : channels) channel.dmaRun();
|
for(auto& channel : channels) channel.dmaRun();
|
||||||
|
@ -25,12 +26,14 @@ auto CPU::hdmaReset() -> void {
|
||||||
}
|
}
|
||||||
|
|
||||||
auto CPU::hdmaSetup() -> void {
|
auto CPU::hdmaSetup() -> void {
|
||||||
|
counter.dma += 8;
|
||||||
step<8,0>();
|
step<8,0>();
|
||||||
for(auto& channel : channels) channel.hdmaSetup();
|
for(auto& channel : channels) channel.hdmaSetup();
|
||||||
status.irqLock = true;
|
status.irqLock = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto CPU::hdmaRun() -> void {
|
auto CPU::hdmaRun() -> void {
|
||||||
|
counter.dma += 8;
|
||||||
step<8,0>();
|
step<8,0>();
|
||||||
for(auto& channel : channels) channel.hdmaTransfer();
|
for(auto& channel : channels) channel.hdmaTransfer();
|
||||||
for(auto& channel : channels) channel.hdmaAdvance();
|
for(auto& channel : channels) channel.hdmaAdvance();
|
||||||
|
@ -40,8 +43,14 @@ auto CPU::hdmaRun() -> void {
|
||||||
//
|
//
|
||||||
|
|
||||||
template<uint Clocks, bool Synchronize>
|
template<uint Clocks, bool Synchronize>
|
||||||
auto CPU::Channel::step() -> void { return cpu.step<Clocks, Synchronize>(); }
|
auto CPU::Channel::step() -> void {
|
||||||
auto CPU::Channel::edge() -> void { return cpu.dmaEdge(); }
|
cpu.counter.dma += Clocks;
|
||||||
|
cpu.step<Clocks, Synchronize>();
|
||||||
|
}
|
||||||
|
|
||||||
|
auto CPU::Channel::edge() -> void {
|
||||||
|
cpu.dmaEdge();
|
||||||
|
}
|
||||||
|
|
||||||
auto CPU::Channel::validA(uint24 address) -> bool {
|
auto CPU::Channel::validA(uint24 address) -> bool {
|
||||||
//A-bus cannot access the B-bus or CPU I/O registers
|
//A-bus cannot access the B-bus or CPU I/O registers
|
||||||
|
|
|
@ -1,12 +1,3 @@
|
||||||
//the number of clock cycles that have elapsed since (H)DMA began
|
|
||||||
auto CPU::dmaClocks() const -> uint {
|
|
||||||
if(counter.cpu >= counter.dma) {
|
|
||||||
return counter.cpu - counter.dma;
|
|
||||||
} else {
|
|
||||||
return 0 - counter.cpu + counter.dma;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//DMA clock divider
|
//DMA clock divider
|
||||||
auto CPU::dmaCounter() const -> uint {
|
auto CPU::dmaCounter() const -> uint {
|
||||||
return counter.cpu & 7;
|
return counter.cpu & 7;
|
||||||
|
@ -150,12 +141,11 @@ auto CPU::dmaEdge() -> void {
|
||||||
status.hdmaPending = false;
|
status.hdmaPending = false;
|
||||||
if(hdmaEnable()) {
|
if(hdmaEnable()) {
|
||||||
if(!dmaEnable()) {
|
if(!dmaEnable()) {
|
||||||
counter.dma = counter.cpu;
|
step(counter.dma = 8 - dmaCounter());
|
||||||
step(8 - dmaCounter());
|
|
||||||
}
|
}
|
||||||
status.hdmaMode == 0 ? hdmaSetup() : hdmaRun();
|
status.hdmaMode == 0 ? hdmaSetup() : hdmaRun();
|
||||||
if(!dmaEnable()) {
|
if(!dmaEnable()) {
|
||||||
step(status.clockCount - dmaClocks() % status.clockCount);
|
step(status.clockCount - counter.dma % status.clockCount);
|
||||||
status.dmaActive = false;
|
status.dmaActive = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -164,10 +154,9 @@ auto CPU::dmaEdge() -> void {
|
||||||
if(status.dmaPending) {
|
if(status.dmaPending) {
|
||||||
status.dmaPending = false;
|
status.dmaPending = false;
|
||||||
if(dmaEnable()) {
|
if(dmaEnable()) {
|
||||||
counter.dma = counter.cpu;
|
step(counter.dma = 8 - dmaCounter());
|
||||||
step(8 - dmaCounter());
|
|
||||||
dmaRun();
|
dmaRun();
|
||||||
step(status.clockCount - dmaClocks() % status.clockCount);
|
step(status.clockCount - counter.dma % status.clockCount);
|
||||||
status.dmaActive = false;
|
status.dmaActive = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue