* fix more AES bugs

* fix ass-stupid bug with NWRAM mapping
This commit is contained in:
Arisotura 2019-06-20 01:36:10 +02:00
parent 95f4c1472b
commit 3d9e6c5c66
2 changed files with 41 additions and 11 deletions

View File

@ -52,8 +52,8 @@ u8 NWRAM_B[0x40000];
u8 NWRAM_C[0x40000]; u8 NWRAM_C[0x40000];
u8* NWRAMMap_A[2][4]; u8* NWRAMMap_A[2][4];
u8* NWRAMMap_B[3][4]; u8* NWRAMMap_B[3][8];
u8* NWRAMMap_C[3][4]; u8* NWRAMMap_C[3][8];
u32 NWRAMStart[2][3]; u32 NWRAMStart[2][3];
u32 NWRAMEnd[2][3]; u32 NWRAMEnd[2][3];

View File

@ -32,6 +32,8 @@ u32 Cnt;
u32 BlkCnt; u32 BlkCnt;
u32 RemBlocks; u32 RemBlocks;
bool OutputFlush;
u32 InputDMASize, OutputDMASize; u32 InputDMASize, OutputDMASize;
u32 AESMode; u32 AESMode;
@ -73,6 +75,7 @@ void ROL16(u8* val, u32 n)
} }
#define _printhex(str, size) { for (int z = 0; z < (size); z++) printf("%02X", (str)[z]); printf("\n"); } #define _printhex(str, size) { for (int z = 0; z < (size); z++) printf("%02X", (str)[z]); printf("\n"); }
#define _printhex2(str, size) { for (int z = 0; z < (size); z++) printf("%02X", (str)[z]); }
bool Init() bool Init()
@ -99,6 +102,8 @@ void Reset()
BlkCnt = 0; BlkCnt = 0;
RemBlocks = 0; RemBlocks = 0;
OutputFlush = false;
InputDMASize = 0; InputDMASize = 0;
OutputDMASize = 0; OutputDMASize = 0;
AESMode = 0; AESMode = 0;
@ -114,6 +119,10 @@ void Reset()
// initialize keys, as per GBAtek // initialize keys, as per GBAtek
// slot 0: modcrypt
*(u32*)&KeyX[0][0] = 0x746E694E;
*(u32*)&KeyX[0][4] = 0x6F646E65;
// slot 3: console-unique eMMC crypto // slot 3: console-unique eMMC crypto
*(u32*)&KeyX[3][0] = (u32)DSi::ConsoleID; *(u32*)&KeyX[3][0] = (u32)DSi::ConsoleID;
*(u32*)&KeyX[3][4] = (u32)DSi::ConsoleID ^ 0x24EE6906; *(u32*)&KeyX[3][4] = (u32)DSi::ConsoleID ^ 0x24EE6906;
@ -135,13 +144,13 @@ void ProcessBlock_CTR()
*(u32*)&data[8] = InputFIFO->Read(); *(u32*)&data[8] = InputFIFO->Read();
*(u32*)&data[12] = InputFIFO->Read(); *(u32*)&data[12] = InputFIFO->Read();
//printf("AES-CTR: INPUT: "); _printhex(data, 16); //printf("AES-CTR: "); _printhex2(data, 16);
Swap16(data_rev, data); Swap16(data_rev, data);
AES_CTR_xcrypt_buffer(&Ctx, data_rev, 16); AES_CTR_xcrypt_buffer(&Ctx, data_rev, 16);
Swap16(data, data_rev); Swap16(data, data_rev);
//printf("AES-CTR: OUTPUT: "); _printhex(data, 16); //printf(" -> "); _printhex(data, 16);
OutputFIFO->Write(*(u32*)&data[0]); OutputFIFO->Write(*(u32*)&data[0]);
OutputFIFO->Write(*(u32*)&data[4]); OutputFIFO->Write(*(u32*)&data[4]);
@ -165,8 +174,11 @@ void WriteCnt(u32 val)
u32 oldcnt = Cnt; u32 oldcnt = Cnt;
Cnt = val & 0xFC1FF000; Cnt = val & 0xFC1FF000;
if (val & (1<<10)) InputFIFO->Clear(); /*if (val & (3<<10))
if (val & (1<<11)) OutputFIFO->Clear(); {
if (val & (1<<11)) OutputFlush = true;
Update();
}*/
u32 dmasize[4] = {4, 8, 12, 16}; u32 dmasize[4] = {4, 8, 12, 16};
InputDMASize = dmasize[3 - ((val >> 12) & 0x3)]; InputDMASize = dmasize[3 - ((val >> 12) & 0x3)];
@ -208,8 +220,19 @@ u32 ReadOutputFIFO()
{ {
u32 ret = OutputFIFO->Read(); u32 ret = OutputFIFO->Read();
if (Cnt & (1<<31))
{
CheckInputDMA(); CheckInputDMA();
CheckOutputDMA(); CheckOutputDMA();
}
else
{
if (OutputFIFO->Level() > 0)
DSi::CheckNDMAs(1, 0x2B);
else
DSi::StopNDMAs(1, 0x2B);
}
return ret; return ret;
} }
@ -226,6 +249,8 @@ void WriteInputFIFO(u32 val)
void CheckInputDMA() void CheckInputDMA()
{ {
if (RemBlocks == 0) return;
if (InputFIFO->Level() < InputDMASize) if (InputFIFO->Level() < InputDMASize)
{ {
// trigger input DMA // trigger input DMA
@ -270,7 +295,12 @@ void Update()
Cnt &= ~(1<<31); Cnt &= ~(1<<31);
if (Cnt & (1<<30)) NDS::SetIRQ2(NDS::IRQ2_DSi_AES); if (Cnt & (1<<30)) NDS::SetIRQ2(NDS::IRQ2_DSi_AES);
DSi::StopNDMAs(1, 0x2A); DSi::StopNDMAs(1, 0x2A);
if (OutputFIFO->Level() > 0)
DSi::CheckNDMAs(1, 0x2B);
else
DSi::StopNDMAs(1, 0x2B); DSi::StopNDMAs(1, 0x2B);
OutputFlush = false;
} }
} }
@ -298,8 +328,8 @@ void DeriveNormalKey(u32 slot)
const u8 key_const[16] = {0xFF, 0xFE, 0xFB, 0x4E, 0x29, 0x59, 0x02, 0x58, 0x2A, 0x68, 0x0F, 0x5F, 0x1A, 0x4F, 0x3E, 0x79}; const u8 key_const[16] = {0xFF, 0xFE, 0xFB, 0x4E, 0x29, 0x59, 0x02, 0x58, 0x2A, 0x68, 0x0F, 0x5F, 0x1A, 0x4F, 0x3E, 0x79};
u8 tmp[16]; u8 tmp[16];
//printf("keyX: "); _printhex(KeyX[slot], 16); //printf("slot%d keyX: ", slot); _printhex(KeyX[slot], 16);
//printf("keyY: "); _printhex(KeyY[slot], 16); //printf("slot%d keyY: ", slot); _printhex(KeyY[slot], 16);
for (int i = 0; i < 16; i++) for (int i = 0; i < 16; i++)
tmp[i] = KeyX[slot][i] ^ KeyY[slot][i]; tmp[i] = KeyX[slot][i] ^ KeyY[slot][i];