unfuck the DSP enough that it will actually run code

(don't get your hopes up, it's still pretty much a trainwreck)
This commit is contained in:
Arisotura 2022-10-11 00:26:42 +02:00
parent 9a85bc7453
commit b33f0434a6
3 changed files with 22 additions and 9 deletions

View File

@ -2365,7 +2365,7 @@ void ARM9IOWrite8(u32 addr, u8 val)
return; return;
case 0x04004006: case 0x04004006:
if (!(SCFG_EXT[1] & (1 << 31))) /* no access to SCFG Registers if disabled*/ if (!(SCFG_EXT[0] & (1 << 31))) /* no access to SCFG Registers if disabled*/
return; return;
SCFG_RST = (SCFG_RST & 0xFF00) | val; SCFG_RST = (SCFG_RST & 0xFF00) | val;
DSi_DSP::SetRstLine(val & 1); DSi_DSP::SetRstLine(val & 1);
@ -2375,7 +2375,7 @@ void ARM9IOWrite8(u32 addr, u8 val)
case 0x04004041: case 0x04004041:
case 0x04004042: case 0x04004042:
case 0x04004043: case 0x04004043:
if (!(SCFG_EXT[1] & (1 << 31))) /* no access to SCFG Registers if disabled*/ if (!(SCFG_EXT[0] & (1 << 31))) /* no access to SCFG Registers if disabled*/
return; return;
MapNWRAM_A(addr & 3, val); MapNWRAM_A(addr & 3, val);
return; return;
@ -2387,7 +2387,7 @@ void ARM9IOWrite8(u32 addr, u8 val)
case 0x04004049: case 0x04004049:
case 0x0400404A: case 0x0400404A:
case 0x0400404B: case 0x0400404B:
if (!(SCFG_EXT[1] & (1 << 31))) /* no access to SCFG Registers if disabled*/ if (!(SCFG_EXT[0] & (1 << 31))) /* no access to SCFG Registers if disabled*/
return; return;
MapNWRAM_B((addr - 0x04) & 7, val); MapNWRAM_B((addr - 0x04) & 7, val);
return; return;
@ -2399,7 +2399,7 @@ void ARM9IOWrite8(u32 addr, u8 val)
case 0x04004051: case 0x04004051:
case 0x04004052: case 0x04004052:
case 0x04004053: case 0x04004053:
if (!(SCFG_EXT[1] & (1 << 31))) /* no access to SCFG Registers if disabled*/ if (!(SCFG_EXT[0] & (1 << 31))) /* no access to SCFG Registers if disabled*/
return; return;
MapNWRAM_C((addr-0x0C) & 7, val); MapNWRAM_C((addr-0x0C) & 7, val);
return; return;

View File

@ -214,6 +214,11 @@ inline bool IsDSPCoreEnabled()
return (DSi::SCFG_Clock9 & (1<<1)) && SCFG_RST && (!(DSP_PCFG & (1<<0))); return (DSi::SCFG_Clock9 & (1<<1)) && SCFG_RST && (!(DSP_PCFG & (1<<0)));
} }
inline bool IsDSPIOEnabled()
{
return (DSi::SCFG_Clock9 & (1<<1)) && SCFG_RST;
}
bool DSPCatchUp() bool DSPCatchUp()
{ {
//asm volatile("int3"); //asm volatile("int3");
@ -390,7 +395,8 @@ u16 PDataDMAReadMMIO()
u8 Read8(u32 addr) u8 Read8(u32 addr)
{ {
if (!DSPCatchUp()) return 0; if (!IsDSPIOEnabled()) return 0;
DSPCatchUp();
addr &= 0x3F; // mirroring wheee addr &= 0x3F; // mirroring wheee
@ -416,7 +422,9 @@ u8 Read8(u32 addr)
} }
u16 Read16(u32 addr) u16 Read16(u32 addr)
{ {
if (!DSPCatchUp()) return 0; //printf("DSP READ16 %d %08X %08X\n", IsDSPCoreEnabled(), addr, NDS::GetPC(0));
if (!IsDSPIOEnabled()) return 0;
DSPCatchUp();
addr &= 0x3E; // mirroring wheee addr &= 0x3E; // mirroring wheee
@ -464,7 +472,8 @@ u32 Read32(u32 addr)
void Write8(u32 addr, u8 val) void Write8(u32 addr, u8 val)
{ {
if (!DSPCatchUp()) return; if (!IsDSPIOEnabled()) return;
DSPCatchUp();
addr &= 0x3F; addr &= 0x3F;
switch (addr) switch (addr)
@ -484,7 +493,9 @@ void Write8(u32 addr, u8 val)
} }
void Write16(u32 addr, u16 val) void Write16(u32 addr, u16 val)
{ {
if (!DSPCatchUp()) return; //printf("DSP WRITE16 %d %08X %08X %08X\n", IsDSPCoreEnabled(), addr, val, NDS::GetPC(0));
if (!IsDSPIOEnabled()) return;
DSPCatchUp();
addr &= 0x3E; addr &= 0x3E;
switch (addr) switch (addr)
@ -494,6 +505,8 @@ void Write16(u32 addr, u16 val)
case 0x08: case 0x08:
DSP_PCFG = val; DSP_PCFG = val;
if (DSP_PCFG & (1<<0))
TeakraCore->Reset();
if (DSP_PCFG & (1<<4)) if (DSP_PCFG & (1<<4))
PDataDMAStart(); PDataDMAStart();
else else

View File

@ -50,7 +50,7 @@ struct Teakra::Impl {
} }
void Reset() { void Reset() {
shared_memory.raw.fill(0); // BAD!!!! //shared_memory.raw.fill(0); // BAD!!!!
miu.Reset(); miu.Reset();
apbp_from_cpu.Reset(); apbp_from_cpu.Reset();
apbp_from_dsp.Reset(); apbp_from_dsp.Reset();