Re-added the DMA Prefetch buffer. This fixes Phantasy Star Collection.

git-svn-id: https://svn.code.sf.net/p/vbam/code/trunk@1200 a31d4220-a93d-0410-bf67-fe4944624d44
This commit is contained in:
normmatt234 2013-09-14 08:00:19 +00:00
parent 22f63644ef
commit 40f0a74ac1
2 changed files with 54 additions and 22 deletions

View File

@ -42,6 +42,7 @@ bool busPrefetchEnable = false;
u32 busPrefetchCount = 0; u32 busPrefetchCount = 0;
int cpuDmaTicksToUpdate = 0; int cpuDmaTicksToUpdate = 0;
int cpuDmaCount = 0; int cpuDmaCount = 0;
bool cpuDmaHack = false;
u32 cpuDmaLast = 0; u32 cpuDmaLast = 0;
int dummyAddress = 0; int dummyAddress = 0;
@ -119,6 +120,9 @@ int capture = 0;
int capturePrevious = 0; int capturePrevious = 0;
int captureNumber = 0; int captureNumber = 0;
int armOpcodeCount = 0;
int thumbOpcodeCount = 0;
const int TIMER_TICKS[4] = { const int TIMER_TICKS[4] = {
0, 0,
6, 6,
@ -2183,6 +2187,7 @@ void CPUCheckDMA(int reason, int dmamask)
doDMA(dma0Source, dma0Dest, sourceIncrement, destIncrement, doDMA(dma0Source, dma0Dest, sourceIncrement, destIncrement,
DM0CNT_L ? DM0CNT_L : 0x4000, DM0CNT_L ? DM0CNT_L : 0x4000,
DM0CNT_H & 0x0400); DM0CNT_H & 0x0400);
cpuDmaHack = true;
if(DM0CNT_H & 0x4000) { if(DM0CNT_H & 0x4000) {
IF |= 0x0100; IF |= 0x0100;
@ -2251,6 +2256,7 @@ void CPUCheckDMA(int reason, int dmamask)
DM1CNT_L ? DM1CNT_L : 0x4000, DM1CNT_L ? DM1CNT_L : 0x4000,
DM1CNT_H & 0x0400); DM1CNT_H & 0x0400);
} }
cpuDmaHack = true;
if(DM1CNT_H & 0x4000) { if(DM1CNT_H & 0x4000) {
IF |= 0x0200; IF |= 0x0200;
@ -2320,6 +2326,7 @@ void CPUCheckDMA(int reason, int dmamask)
DM2CNT_L ? DM2CNT_L : 0x4000, DM2CNT_L ? DM2CNT_L : 0x4000,
DM2CNT_H & 0x0400); DM2CNT_H & 0x0400);
} }
cpuDmaHack = true;
if(DM2CNT_H & 0x4000) { if(DM2CNT_H & 0x4000) {
IF |= 0x0400; IF |= 0x0400;
@ -2376,6 +2383,8 @@ void CPUCheckDMA(int reason, int dmamask)
doDMA(dma3Source, dma3Dest, sourceIncrement, destIncrement, doDMA(dma3Source, dma3Dest, sourceIncrement, destIncrement,
DM3CNT_L ? DM3CNT_L : 0x10000, DM3CNT_L ? DM3CNT_L : 0x10000,
DM3CNT_H & 0x0400); DM3CNT_H & 0x0400);
cpuDmaHack = true;
if(DM3CNT_H & 0x4000) { if(DM3CNT_H & 0x4000) {
IF |= 0x0800; IF |= 0x0800;
UPDATE_REG(0x202, IF); UPDATE_REG(0x202, IF);
@ -2422,7 +2431,7 @@ void CPUUpdateRegister(u32 address, u16 value)
windowOn = (layerEnable & 0x6000) ? true : false; windowOn = (layerEnable & 0x6000) ? true : false;
if(change && !((value & 0x80))) { if(change && !((value & 0x80))) {
if(!(DISPSTAT & 1)) { if(!(DISPSTAT & 1)) {
lcdTicks = 1008; //lcdTicks = 1008;
// VCOUNT = 0; // VCOUNT = 0;
// UPDATE_REG(0x06, VCOUNT); // UPDATE_REG(0x06, VCOUNT);
DISPSTAT &= 0xFFFC; DISPSTAT &= 0xFFFC;
@ -3071,13 +3080,13 @@ void CPUInit(const char *biosFileName, bool useBiosFile)
ioReadable[i] = false; ioReadable[i] = false;
for(i = 0x8c; i < 0x90; i++) for(i = 0x8c; i < 0x90; i++)
ioReadable[i] = false; ioReadable[i] = false;
for(i = 0xa0; i < 0xb8; i++) for(i = 0xa0; i < 0xba; i++)
ioReadable[i] = false; ioReadable[i] = false;
for(i = 0xbc; i < 0xc4; i++) for(i = 0xbc; i < 0xc6; i++)
ioReadable[i] = false; ioReadable[i] = false;
for(i = 0xc8; i < 0xd0; i++) for(i = 0xc8; i < 0xd0; i++)
ioReadable[i] = false; ioReadable[i] = false;
for(i = 0xd4; i < 0xdc; i++) for(i = 0xd4; i < 0xde; i++)
ioReadable[i] = false; ioReadable[i] = false;
for(i = 0xe0; i < 0x100; i++) for(i = 0xe0; i < 0x100; i++)
ioReadable[i] = false; ioReadable[i] = false;
@ -3400,6 +3409,8 @@ void CPUReset()
systemSaveUpdateCounter = SYSTEM_SAVE_NOT_UPDATED; systemSaveUpdateCounter = SYSTEM_SAVE_NOT_UPDATED;
cpuDmaHack = false;
lastTime = systemGetClock(); lastTime = systemGetClock();
SWITicks = 0; SWITicks = 0;
@ -3473,9 +3484,11 @@ void CPULoop(int ticks)
if(!holdState && !SWITicks) { if(!holdState && !SWITicks) {
if(armState) { if(armState) {
armOpcodeCount++;
if (!armExecute()) if (!armExecute())
return; return;
} else { } else {
thumbOpcodeCount++;
if (!thumbExecute()) if (!thumbExecute())
return; return;
} }
@ -3498,6 +3511,7 @@ void CPULoop(int ticks)
clockTicks = cpuNextEvent; clockTicks = cpuNextEvent;
cpuTotalTicks = 0; cpuTotalTicks = 0;
cpuDmaHack = false;
updateLoop: updateLoop:
@ -3531,7 +3545,7 @@ void CPULoop(int ticks)
} }
} }
if(VCOUNT >= 228) { //Reaching last line if(VCOUNT > 227) { //Reaching last line
DISPSTAT &= 0xFFFC; DISPSTAT &= 0xFFFC;
UPDATE_REG(0x04, DISPSTAT); UPDATE_REG(0x04, DISPSTAT);
VCOUNT = 0; VCOUNT = 0;
@ -3899,6 +3913,7 @@ void CPULoop(int ticks)
cpuDmaTicksToUpdate -= clockTicks; cpuDmaTicksToUpdate -= clockTicks;
if(cpuDmaTicksToUpdate < 0) if(cpuDmaTicksToUpdate < 0)
cpuDmaTicksToUpdate = 0; cpuDmaTicksToUpdate = 0;
cpuDmaHack = true;
goto updateLoop; goto updateLoop;
} }

View File

@ -19,6 +19,7 @@ extern bool cpuSramEnabled;
extern bool cpuFlashEnabled; extern bool cpuFlashEnabled;
extern bool cpuEEPROMEnabled; extern bool cpuEEPROMEnabled;
extern bool cpuEEPROMSensorEnabled; extern bool cpuEEPROMSensorEnabled;
extern bool cpuDmaHack;
extern u32 cpuDmaLast; extern u32 cpuDmaLast;
extern bool timer0On; extern bool timer0On;
extern int timer0Ticks; extern int timer0Ticks;
@ -130,12 +131,16 @@ unreadable:
armNextPC - 4 : armNextPC - 2); armNextPC - 4 : armNextPC - 2);
} }
#endif #endif
if(armState) { if(cpuDmaHack) {
value = cpuDmaLast;
} else {
if(armState) {
return CPUReadMemoryQuick(reg[15].I); return CPUReadMemoryQuick(reg[15].I);
} else { } else {
return CPUReadHalfWordQuick(reg[15].I) | return CPUReadHalfWordQuick(reg[15].I) |
CPUReadHalfWordQuick(reg[15].I) << 16; CPUReadHalfWordQuick(reg[15].I) << 16;
} }
}
} }
if(oldAddress & 3) { if(oldAddress & 3) {
@ -222,6 +227,10 @@ static inline u32 CPUReadHalfWord(u32 address)
value = 0xFFFF - ((timer3Ticks-cpuTotalTicks) >> timer3ClockReload); value = 0xFFFF - ((timer3Ticks-cpuTotalTicks) >> timer3ClockReload);
} }
} }
else if((address < 0x4000400) && ioReadable[address & 0x3fc])
{
value = 0;
}
else goto unreadable; else goto unreadable;
break; break;
case 5: case 5:
@ -263,18 +272,22 @@ static inline u32 CPUReadHalfWord(u32 address)
// default // default
default: default:
unreadable: unreadable:
#ifdef GBA_LOGGING if(cpuDmaHack) {
if(systemVerbose & VERBOSE_ILLEGAL_READ) { value = cpuDmaLast & 0xFFFF;
log("Illegal halfword read: %08x at %08x\n", oldAddress, armMode ?
armNextPC - 4 : armNextPC - 2);
}
#endif
if(armState) {
return CPUReadMemoryQuick(reg[15].I);
} else { } else {
return CPUReadHalfWordQuick(reg[15].I) | if(armState) {
CPUReadHalfWordQuick(reg[15].I) << 16; value = CPUReadMemoryQuick(reg[15].I);
} else {
value = CPUReadHalfWordQuick(reg[15].I) |
CPUReadHalfWordQuick(reg[15].I) << 16;
}
} }
#ifdef GBA_LOGGING
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
log("Illegal halfword read: %08x at %08x (%08x)\n", oldAddress, reg[15].I, value);
}
#endif
return value;
} }
if(oldAddress & 1) { if(oldAddress & 1) {
@ -379,11 +392,15 @@ unreadable:
armNextPC - 4 : armNextPC - 2); armNextPC - 4 : armNextPC - 2);
} }
#endif #endif
if(armState) { if(cpuDmaHack) {
return CPUReadMemoryQuick(reg[15].I); return cpuDmaLast & 0xFF;
} else { } else {
return CPUReadHalfWordQuick(reg[15].I) | if(armState) {
CPUReadHalfWordQuick(reg[15].I) << 16; return CPUReadMemoryQuick(reg[15].I);
} else {
return CPUReadHalfWordQuick(reg[15].I) |
CPUReadHalfWordQuick(reg[15].I) << 16;
}
} }
} }
} }