some attempt at actually stubbing out wifi. except it won't fucking work.
This commit is contained in:
parent
2fef876eeb
commit
f2622c047b
|
@ -803,8 +803,11 @@ void debug(u32 param)
|
||||||
printf("ARM9 PC=%08X LR=%08X %08X\n", ARM9->R[15], ARM9->R[14], ARM9->R_IRQ[1]);
|
printf("ARM9 PC=%08X LR=%08X %08X\n", ARM9->R[15], ARM9->R[14], ARM9->R_IRQ[1]);
|
||||||
printf("ARM7 PC=%08X LR=%08X %08X\n", ARM7->R[15], ARM7->R[14], ARM7->R_IRQ[1]);
|
printf("ARM7 PC=%08X LR=%08X %08X\n", ARM7->R[15], ARM7->R[14], ARM7->R_IRQ[1]);
|
||||||
|
|
||||||
for (int i = 0; i < 9; i++)
|
printf("ARM9 IME=%08X IE=%08X IF=%08X\n", IME[0], IE[0], IF[0]);
|
||||||
printf("VRAM %c: %02X\n", 'A'+i, GPU::VRAMCNT[i]);
|
printf("ARM7 IME=%08X IE=%08X IF=%08X\n", IME[1], IE[1], IF[1]);
|
||||||
|
|
||||||
|
//for (int i = 0; i < 9; i++)
|
||||||
|
// printf("VRAM %c: %02X\n", 'A'+i, GPU::VRAMCNT[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
61
src/Wifi.cpp
61
src/Wifi.cpp
|
@ -27,6 +27,9 @@ namespace Wifi
|
||||||
{
|
{
|
||||||
|
|
||||||
u8 RAM[0x2000];
|
u8 RAM[0x2000];
|
||||||
|
u16 IO[0x1000>>1];
|
||||||
|
|
||||||
|
#define IOPORT(x) IO[(x)>>1]
|
||||||
|
|
||||||
u16 Random;
|
u16 Random;
|
||||||
|
|
||||||
|
@ -45,8 +48,9 @@ u32 RFRegs[0x40];
|
||||||
void Reset()
|
void Reset()
|
||||||
{
|
{
|
||||||
memset(RAM, 0, 0x2000);
|
memset(RAM, 0, 0x2000);
|
||||||
|
memset(IO, 0, 0x1000);
|
||||||
|
|
||||||
Random = 0x7FF;
|
Random = 1;
|
||||||
|
|
||||||
BBCnt = 0;
|
BBCnt = 0;
|
||||||
BBWrite = 0;
|
BBWrite = 0;
|
||||||
|
@ -86,6 +90,9 @@ void Reset()
|
||||||
RFData1 = 0;
|
RFData1 = 0;
|
||||||
RFData2 = 0;
|
RFData2 = 0;
|
||||||
memset(RFRegs, 0, 4*0x40);
|
memset(RFRegs, 0, 4*0x40);
|
||||||
|
|
||||||
|
memset(&IOPORT(0x018), 0xFF, 6);
|
||||||
|
memset(&IOPORT(0x020), 0xFF, 6);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -127,11 +134,11 @@ void RFTransfer_Type3()
|
||||||
|
|
||||||
u16 Read(u32 addr)
|
u16 Read(u32 addr)
|
||||||
{
|
{
|
||||||
addr &= 0x7FFF;
|
addr &= 0x7FFE;
|
||||||
|
//printf("WIFI: read %08X\n", addr);
|
||||||
if (addr >= 0x4000 && addr < 0x6000)
|
if (addr >= 0x4000 && addr < 0x6000)
|
||||||
{
|
{
|
||||||
return *(u16*)&RAM[addr & 0x1FFF];
|
return *(u16*)&RAM[addr & 0x1FFE];
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (addr)
|
switch (addr)
|
||||||
|
@ -140,6 +147,9 @@ u16 Read(u32 addr)
|
||||||
Random = (Random & 0x1) ^ (((Random & 0x3FF) << 1) | (Random >> 10));
|
Random = (Random & 0x1) ^ (((Random & 0x3FF) << 1) | (Random >> 10));
|
||||||
return Random;
|
return Random;
|
||||||
|
|
||||||
|
case 0x0BC:
|
||||||
|
return IOPORT(0x0BC) & 0x0003;
|
||||||
|
|
||||||
case 0x158:
|
case 0x158:
|
||||||
return BBCnt;
|
return BBCnt;
|
||||||
|
|
||||||
|
@ -164,22 +174,33 @@ u16 Read(u32 addr)
|
||||||
return RFCnt;
|
return RFCnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("WIFI: unknown read %08X\n", addr);
|
//printf("WIFI: read %08X\n", addr);
|
||||||
return 0;
|
return IOPORT(addr&0xFFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Write(u32 addr, u16 val)
|
void Write(u32 addr, u16 val)
|
||||||
{
|
{
|
||||||
addr &= 0x7FFF;
|
addr &= 0x7FFE;
|
||||||
|
//printf("WIFI: write %08X %04X\n", addr, val);
|
||||||
if (addr >= 0x4000 && addr < 0x6000)
|
if (addr >= 0x4000 && addr < 0x6000)
|
||||||
{
|
{
|
||||||
*(u16*)&RAM[addr & 0x1FFF] = val;
|
*(u16*)&RAM[addr & 0x1FFE] = val;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (addr)
|
switch (addr)
|
||||||
{
|
{
|
||||||
|
case 0x006:
|
||||||
|
val &= 0x007F;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0x010:
|
||||||
|
// IF: TODO
|
||||||
|
return;
|
||||||
|
case 0x012:
|
||||||
|
printf("WIFI IE=%04X\n", val);
|
||||||
|
break;
|
||||||
|
|
||||||
case 0x158:
|
case 0x158:
|
||||||
BBCnt = val;
|
BBCnt = val;
|
||||||
if ((BBCnt & 0xF000) == 0x5000)
|
if ((BBCnt & 0xF000) == 0x5000)
|
||||||
|
@ -205,9 +226,29 @@ void Write(u32 addr, u16 val)
|
||||||
case 0x184:
|
case 0x184:
|
||||||
RFCnt = val & 0x413F;
|
RFCnt = val & 0x413F;
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// read-only ports
|
||||||
|
case 0x000:
|
||||||
|
case 0x044:
|
||||||
|
case 0x054:
|
||||||
|
case 0x0B0:
|
||||||
|
case 0x0B6:
|
||||||
|
case 0x0B8:
|
||||||
|
case 0x15C:
|
||||||
|
case 0x15E:
|
||||||
|
case 0x180:
|
||||||
|
case 0x19C:
|
||||||
|
case 0x1A8:
|
||||||
|
case 0x1AC:
|
||||||
|
case 0x1C4:
|
||||||
|
case 0x210:
|
||||||
|
case 0x214:
|
||||||
|
case 0x268:
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("WIFI: unknown write %08X %04X\n", addr, val);
|
//printf("WIFI: write %08X %04X\n", addr, val);
|
||||||
|
IOPORT(addr&0xFFF) = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue