well, GX FIFO base. noting that for now, it doesn't do much beyond getting full real quick.

also make ROM loading fail gracefully if it shits itself, instead of entering an endless loop.
This commit is contained in:
StapleButter 2017-02-07 23:31:21 +01:00
parent 2b7fac05c7
commit 971e7b7e89
7 changed files with 218 additions and 20 deletions

6
FIFO.h
View File

@ -47,7 +47,7 @@ public:
} }
void Write(u32 val) void Write(T& val)
{ {
if (IsFull()) return; if (IsFull()) return;
@ -60,9 +60,9 @@ public:
NumOccupied++; NumOccupied++;
} }
T Read() T& Read()
{ {
T ret = Entries[ReadPos]; T& ret = Entries[ReadPos];
if (IsEmpty()) if (IsEmpty())
return ret; return ret;

174
GPU3D.cpp
View File

@ -26,6 +26,43 @@
namespace GPU3D namespace GPU3D
{ {
const u32 CmdNumParams[256] =
{
// 0x00
0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
// 0x10
1, 0, 1, 1, 1, 0, 16, 12, 16, 12, 9, 3, 3,
0, 0, 0,
// 0x20
1, 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1,
0, 0, 0, 0,
// 0x30
1, 1, 1, 1, 32,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
// 0x40
1, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
// 0x50
1,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
// 0x60
1,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
// 0x70
3, 2, 1,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
// 0x80+
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
};
typedef struct typedef struct
{ {
u8 Command; u8 Command;
@ -36,6 +73,10 @@ typedef struct
FIFO<CmdFIFOEntry>* CmdFIFO; FIFO<CmdFIFOEntry>* CmdFIFO;
FIFO<CmdFIFOEntry>* CmdPIPE; FIFO<CmdFIFOEntry>* CmdPIPE;
u32 NumCommands, CurCommand, ParamCount, TotalParams;
u32 GXStat;
bool Init() bool Init()
{ {
@ -55,6 +96,139 @@ void Reset()
{ {
CmdFIFO->Clear(); CmdFIFO->Clear();
CmdPIPE->Clear(); CmdPIPE->Clear();
NumCommands = 0;
CurCommand = 0;
ParamCount = 0;
TotalParams = 0;
GXStat = 0;
}
void CmdFIFOWrite(CmdFIFOEntry entry)
{
printf("GX FIFO: %02X %08X\n", entry.Command, entry.Param);
if (CmdFIFO->IsEmpty() && !CmdPIPE->IsFull())
{
CmdPIPE->Write(entry);
}
else
{
if (CmdFIFO->IsFull())
{
printf("!!! GX FIFO FULL\n");
return;
}
CmdFIFO->Write(entry);
}
}
CmdFIFOEntry CmdFIFORead()
{
CmdFIFOEntry ret = CmdPIPE->Read();
if (CmdPIPE->Level() <= 2)
{
if (!CmdFIFO->IsEmpty())
CmdPIPE->Write(CmdFIFO->Read());
if (!CmdFIFO->IsEmpty())
CmdPIPE->Write(CmdFIFO->Read());
}
}
u8 Read8(u32 addr)
{
return 0;
}
u16 Read16(u32 addr)
{
return 0;
}
u32 Read32(u32 addr)
{
switch (addr)
{
case 0x04000320:
return 46; // TODO, eventually
case 0x04000600:
{
u32 fifolevel = CmdFIFO->Level();
return GXStat |
// matrix stack levels, TODO
(fifolevel << 16) |
(fifolevel < 128 ? (1<<25) : 0) |
(fifolevel == 0 ? (1<<26) : 0);
}
}
return 0;
}
void Write8(u32 addr, u8 val)
{
//
}
void Write16(u32 addr, u16 val)
{
//
}
void Write32(u32 addr, u32 val)
{
switch (addr)
{
case 0x04000600:
if (val & 0x8000) GXStat &= ~0x8000;
val &= 0xC0000000;
GXStat &= 0x3FFFFFFF;
GXStat |= val;
return;
}
if (addr >= 0x04000400 && addr < 0x04000440)
{
if (NumCommands == 0)
{
NumCommands = 4;
CurCommand = val;
ParamCount = 0;
TotalParams = CmdNumParams[CurCommand & 0xFF];
}
else
ParamCount++;
while (ParamCount == TotalParams)
{
CmdFIFOEntry entry;
entry.Command = CurCommand & 0xFF;
entry.Param = val;
CmdFIFOWrite(entry);
CurCommand >>= 8;
NumCommands--;
if (NumCommands == 0) break;
ParamCount = 0;
TotalParams = CmdNumParams[CurCommand & 0xFF];
}
}
if (addr >= 0x04000440 && addr < 0x040005CC)
{
CmdFIFOEntry entry;
entry.Command = (addr & 0x1FC) >> 2;
entry.Param = val;
CmdFIFOWrite(entry);
return;
}
} }
} }

View File

@ -26,6 +26,13 @@ bool Init();
void DeInit(); void DeInit();
void Reset(); void Reset();
u8 Read8(u32 addr);
u16 Read16(u32 addr);
u32 Read32(u32 addr);
void Write8(u32 addr, u8 val);
void Write16(u32 addr, u16 val);
void Write32(u32 addr, u32 val);
} }
#endif #endif

27
NDS.cpp
View File

@ -307,9 +307,8 @@ void Reset()
// test // test
//LoadROM(); //LoadROM();
//LoadFirmware(); //LoadFirmware();
NDSCart::LoadROM("rom/mkds.nds"); if (NDSCart::LoadROM("rom/Simple_Tri.nds"))
Running = true; // hax
Running = true; // hax
} }
@ -1288,6 +1287,10 @@ u8 ARM9IORead8(u32 addr)
{ {
return GPU::GPU2D_B->Read8(addr); return GPU::GPU2D_B->Read8(addr);
} }
if (addr >= 0x04000320 && addr < 0x040006A4)
{
return GPU3D::Read8(addr);
}
printf("unknown ARM9 IO read8 %08X\n", addr); printf("unknown ARM9 IO read8 %08X\n", addr);
return 0; return 0;
@ -1364,6 +1367,10 @@ u16 ARM9IORead16(u32 addr)
{ {
return GPU::GPU2D_B->Read16(addr); return GPU::GPU2D_B->Read16(addr);
} }
if (addr >= 0x04000320 && addr < 0x040006A4)
{
return GPU3D::Read16(addr);
}
printf("unknown ARM9 IO read16 %08X %08X\n", addr, ARM9->R[15]); printf("unknown ARM9 IO read16 %08X %08X\n", addr, ARM9->R[15]);
return 0; return 0;
@ -1418,8 +1425,6 @@ u32 ARM9IORead32(u32 addr)
case 0x040002B8: return SqrtVal[0]; case 0x040002B8: return SqrtVal[0];
case 0x040002BC: return SqrtVal[1]; case 0x040002BC: return SqrtVal[1];
case 0x04000600: return 0x06000000; // hax
case 0x04100000: case 0x04100000:
if (IPCFIFOCnt9 & 0x8000) if (IPCFIFOCnt9 & 0x8000)
{ {
@ -1456,8 +1461,7 @@ u32 ARM9IORead32(u32 addr)
} }
if (addr >= 0x04000320 && addr < 0x040006A4) if (addr >= 0x04000320 && addr < 0x040006A4)
{ {
// 3D GPU return GPU3D::Read32(addr);
return 0;
} }
printf("unknown ARM9 IO read32 %08X\n", addr); printf("unknown ARM9 IO read32 %08X\n", addr);
@ -1522,6 +1526,11 @@ void ARM9IOWrite8(u32 addr, u8 val)
GPU::GPU2D_B->Write8(addr, val); GPU::GPU2D_B->Write8(addr, val);
return; return;
} }
if (addr >= 0x04000320 && addr < 0x040006A4)
{
GPU3D::Write8(addr, val);
return;
}
printf("unknown ARM9 IO write8 %08X %02X\n", addr, val); printf("unknown ARM9 IO write8 %08X %02X\n", addr, val);
} }
@ -1641,7 +1650,7 @@ void ARM9IOWrite16(u32 addr, u16 val)
} }
if (addr >= 0x04000320 && addr < 0x040006A4) if (addr >= 0x04000320 && addr < 0x040006A4)
{ {
// 3D GPU GPU3D::Write16(addr, val);
return; return;
} }
@ -1760,7 +1769,7 @@ void ARM9IOWrite32(u32 addr, u32 val)
} }
if (addr >= 0x04000320 && addr < 0x040006A4) if (addr >= 0x04000320 && addr < 0x040006A4)
{ {
// 3D GPU GPU3D::Write32(addr, val);
return; return;
} }

View File

@ -601,12 +601,17 @@ void Reset()
} }
void LoadROM(char* path) bool LoadROM(char* path)
{ {
// TODO: streaming mode? for really big ROMs or systems with limited RAM // TODO: streaming mode? for really big ROMs or systems with limited RAM
// for now we're lazy // for now we're lazy
FILE* f = fopen(path, "rb"); FILE* f = fopen(path, "rb");
if (!f)
{
printf("Failed to open ROM file %s\n", path);
return false;
}
fseek(f, 0, SEEK_END); fseek(f, 0, SEEK_END);
u32 len = (u32)ftell(f); u32 len = (u32)ftell(f);
@ -674,6 +679,8 @@ void LoadROM(char* path)
strncpy(savepath + strlen(path) - 3, "sav", 3); strncpy(savepath + strlen(path) - 3, "sav", 3);
printf("Save file: %s\n", savepath); printf("Save file: %s\n", savepath);
NDSCart_SRAM::LoadSave(savepath); NDSCart_SRAM::LoadSave(savepath);
return true;
} }
void ReadROM(u32 addr, u32 len, u32 offset) void ReadROM(u32 addr, u32 len, u32 offset)

View File

@ -40,7 +40,7 @@ bool Init();
void DeInit(); void DeInit();
void Reset(); void Reset();
void LoadROM(char* path); bool LoadROM(char* path);
void WriteROMCnt(u32 val); void WriteROMCnt(u32 val);
u32 ReadROMData(); u32 ReadROMData();

View File

@ -10,7 +10,7 @@
1481161027 c:\documents\sources\melonds\types.h 1481161027 c:\documents\sources\melonds\types.h
1486503537 source:c:\documents\sources\melonds\nds.cpp 1486506461 source:c:\documents\sources\melonds\nds.cpp
<stdio.h> <stdio.h>
<string.h> <string.h>
"NDS.h" "NDS.h"
@ -105,7 +105,7 @@
1486501225 source:c:\documents\sources\melonds\fifo.cpp 1486501225 source:c:\documents\sources\melonds\fifo.cpp
"FIFO.h" "FIFO.h"
1486503492 c:\documents\sources\melonds\fifo.h 1486506620 c:\documents\sources\melonds\fifo.h
"types.h" "types.h"
1486309616 source:c:\documents\sources\melonds\dma.cpp 1486309616 source:c:\documents\sources\melonds\dma.cpp
@ -135,20 +135,21 @@
<string.h> <string.h>
"RTC.h" "RTC.h"
1486502165 c:\documents\sources\melonds\ndscart.h 1486506409 c:\documents\sources\melonds\ndscart.h
"types.h" "types.h"
1486502488 source:c:\documents\sources\melonds\ndscart.cpp 1486506451 source:c:\documents\sources\melonds\ndscart.cpp
<stdio.h> <stdio.h>
<string.h> <string.h>
"NDS.h" "NDS.h"
"NDSCart.h" "NDSCart.h"
1486501964 c:\documents\sources\melonds\gpu3d.h 1486503811 c:\documents\sources\melonds\gpu3d.h
1486502427 source:c:\documents\sources\melonds\gpu3d.cpp 1486506240 source:c:\documents\sources\melonds\gpu3d.cpp
<stdio.h> <stdio.h>
<string.h> <string.h>
"NDS.h" "NDS.h"
"GPU.h" "GPU.h"
"FIFO.h"