Added the needed code for the emulation settings dialog.
External BIOS, SWIs from BIOS, external firmware and boot from firmware now working.
This commit is contained in:
parent
6d2ca3ee33
commit
7a998d0d38
|
@ -24,6 +24,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "NDSSystem.h"
|
#include "NDSSystem.h"
|
||||||
|
@ -58,6 +59,339 @@ char ROMserial[20];
|
||||||
|
|
||||||
NDSSystem nds;
|
NDSSystem nds;
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
/* FIRMWARE DECRYPTION */
|
||||||
|
|
||||||
|
static u32 keyBuf[0x412];
|
||||||
|
static u32 keyCode[3];
|
||||||
|
|
||||||
|
#define DWNUM(i) ((i) >> 2)
|
||||||
|
|
||||||
|
u32 bswap32(u32 val)
|
||||||
|
{
|
||||||
|
return (((val & 0x000000FF) << 24) | ((val & 0x0000FF00) << 8) | ((val & 0x00FF0000) >> 8) | ((val & 0xFF000000) >> 24));
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOL getKeyBuf()
|
||||||
|
{
|
||||||
|
/* TODO: make the BIOS image name configurable */
|
||||||
|
|
||||||
|
FILE *file = fopen("./biosnds7.bin", "rb");
|
||||||
|
int dummy;
|
||||||
|
|
||||||
|
if(file == NULL)
|
||||||
|
file = fopen("./bios7.bin", "rb");
|
||||||
|
|
||||||
|
if(file == NULL)
|
||||||
|
file = fopen("./biosnds7.rom", "rb");
|
||||||
|
|
||||||
|
if(file == NULL)
|
||||||
|
file = fopen("./bios7.rom", "rb");
|
||||||
|
|
||||||
|
if(file == NULL)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
fseek(file, 0x30, SEEK_SET);
|
||||||
|
dummy = fread(keyBuf, 0x412, 4, file);
|
||||||
|
|
||||||
|
fclose(file);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void crypt64BitUp(u32 *ptr)
|
||||||
|
{
|
||||||
|
u32 Y = ptr[0];
|
||||||
|
u32 X = ptr[1];
|
||||||
|
|
||||||
|
for(u32 i = 0x00; i <= 0x0F; i++)
|
||||||
|
{
|
||||||
|
u32 Z = (keyBuf[i] ^ X);
|
||||||
|
X = keyBuf[DWNUM(0x048 + (((Z >> 24) & 0xFF) << 2))];
|
||||||
|
X = (keyBuf[DWNUM(0x448 + (((Z >> 16) & 0xFF) << 2))] + X);
|
||||||
|
X = (keyBuf[DWNUM(0x848 + (((Z >> 8) & 0xFF) << 2))] ^ X);
|
||||||
|
X = (keyBuf[DWNUM(0xC48 + ((Z & 0xFF) << 2))] + X);
|
||||||
|
X = (Y ^ X);
|
||||||
|
Y = Z;
|
||||||
|
}
|
||||||
|
|
||||||
|
ptr[0] = (X ^ keyBuf[DWNUM(0x40)]);
|
||||||
|
ptr[1] = (Y ^ keyBuf[DWNUM(0x44)]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void crypt64BitDown(u32 *ptr)
|
||||||
|
{
|
||||||
|
u32 Y = ptr[0];
|
||||||
|
u32 X = ptr[1];
|
||||||
|
|
||||||
|
for(u32 i = 0x11; i >= 0x02; i--)
|
||||||
|
{
|
||||||
|
u32 Z = (keyBuf[i] ^ X);
|
||||||
|
X = keyBuf[DWNUM(0x048 + (((Z >> 24) & 0xFF) << 2))];
|
||||||
|
X = (keyBuf[DWNUM(0x448 + (((Z >> 16) & 0xFF) << 2))] + X);
|
||||||
|
X = (keyBuf[DWNUM(0x848 + (((Z >> 8) & 0xFF) << 2))] ^ X);
|
||||||
|
X = (keyBuf[DWNUM(0xC48 + ((Z & 0xFF) << 2))] + X);
|
||||||
|
X = (Y ^ X);
|
||||||
|
Y = Z;
|
||||||
|
}
|
||||||
|
|
||||||
|
ptr[0] = (X ^ keyBuf[DWNUM(0x04)]);
|
||||||
|
ptr[1] = (Y ^ keyBuf[DWNUM(0x00)]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void applyKeycode(u32 modulo)
|
||||||
|
{
|
||||||
|
crypt64BitUp(&keyCode[1]);
|
||||||
|
crypt64BitUp(&keyCode[0]);
|
||||||
|
|
||||||
|
u32 scratch[2] = {0x00000000, 0x00000000};
|
||||||
|
|
||||||
|
for(u32 i = 0; i <= 0x44; i += 4)
|
||||||
|
{
|
||||||
|
keyBuf[DWNUM(i)] = (keyBuf[DWNUM(i)] ^ bswap32(keyCode[DWNUM(i % modulo)]));
|
||||||
|
}
|
||||||
|
|
||||||
|
for(u32 i = 0; i <= 0x1040; i += 8)
|
||||||
|
{
|
||||||
|
crypt64BitUp(scratch);
|
||||||
|
keyBuf[DWNUM(i)] = scratch[1];
|
||||||
|
keyBuf[DWNUM(i+4)] = scratch[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOL initKeycode(u32 idCode, int level, u32 modulo)
|
||||||
|
{
|
||||||
|
if(getKeyBuf() == FALSE)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
keyCode[0] = idCode;
|
||||||
|
keyCode[1] = (idCode >> 1);
|
||||||
|
keyCode[2] = (idCode << 1);
|
||||||
|
|
||||||
|
if(level >= 1) applyKeycode(modulo);
|
||||||
|
if(level >= 2) applyKeycode(modulo);
|
||||||
|
|
||||||
|
keyCode[1] <<= 1;
|
||||||
|
keyCode[2] >>= 1;
|
||||||
|
|
||||||
|
if(level >= 3) applyKeycode(modulo);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
u16 getBootCodeCRC16()
|
||||||
|
{
|
||||||
|
int i, j;
|
||||||
|
u32 crc = 0xFFFF;
|
||||||
|
const u16 val[8] = {0xC0C1, 0xC181, 0xC301, 0xC601, 0xCC01, 0xD801, 0xF001, 0xA001};
|
||||||
|
|
||||||
|
for(i = 0; i < nds.FW_ARM9BootCodeSize; i++)
|
||||||
|
{
|
||||||
|
crc = (crc ^ nds.FW_ARM9BootCode[i]);
|
||||||
|
|
||||||
|
for(j = 0; j < 8; j++)
|
||||||
|
{
|
||||||
|
if(crc & 0x0001)
|
||||||
|
crc = ((crc >> 1) ^ (val[j] << (7-j)));
|
||||||
|
else
|
||||||
|
crc = (crc >> 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < nds.FW_ARM7BootCodeSize; i++)
|
||||||
|
{
|
||||||
|
crc = (crc ^ nds.FW_ARM7BootCode[i]);
|
||||||
|
|
||||||
|
for(j = 0; j < 8; j++)
|
||||||
|
{
|
||||||
|
if(crc & 0x0001)
|
||||||
|
crc = ((crc >> 1) ^ (val[j] << (7-j)));
|
||||||
|
else
|
||||||
|
crc = (crc >> 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return (crc & 0xFFFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 * decryptFirmwareBlock(char *blockName, u32 *src, u32 &size)
|
||||||
|
{
|
||||||
|
u32 curBlock[2];
|
||||||
|
u32 *dst;
|
||||||
|
u32 header;
|
||||||
|
u32 i, j;
|
||||||
|
u32 xIn = 4, xOut = 0;
|
||||||
|
u32 len;
|
||||||
|
u32 offset;
|
||||||
|
u32 windowOffset;
|
||||||
|
u32 xLen;
|
||||||
|
u8 d;
|
||||||
|
u16 data;
|
||||||
|
|
||||||
|
memcpy(curBlock, src, 8);
|
||||||
|
crypt64BitDown(curBlock);
|
||||||
|
|
||||||
|
u32 blockSize = (curBlock[0] >> 8);
|
||||||
|
size = blockSize;
|
||||||
|
|
||||||
|
INFO("Firmware: %s final size: %i bytes\n", blockName, blockSize);
|
||||||
|
|
||||||
|
dst = (u32*)new u8[blockSize];
|
||||||
|
|
||||||
|
xLen = blockSize;
|
||||||
|
|
||||||
|
while(xLen > 0)
|
||||||
|
{
|
||||||
|
d = T1ReadByte((u8*)curBlock, (xIn % 8));
|
||||||
|
xIn++;
|
||||||
|
if((xIn % 8) == 0)
|
||||||
|
{
|
||||||
|
memcpy(curBlock, (((u8*)src) + xIn), 8);
|
||||||
|
crypt64BitDown(curBlock);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < 8; i++)
|
||||||
|
{
|
||||||
|
if(d & 0x80)
|
||||||
|
{
|
||||||
|
data = (T1ReadByte((u8*)curBlock, (xIn % 8)) << 8);
|
||||||
|
xIn++;
|
||||||
|
if((xIn % 8) == 0)
|
||||||
|
{
|
||||||
|
memcpy(curBlock, (((u8*)src) + xIn), 8);
|
||||||
|
crypt64BitDown(curBlock);
|
||||||
|
}
|
||||||
|
data |= T1ReadByte((u8*)curBlock, (xIn % 8));
|
||||||
|
xIn++;
|
||||||
|
if((xIn % 8) == 0)
|
||||||
|
{
|
||||||
|
memcpy(curBlock, (((u8*)src) + xIn), 8);
|
||||||
|
crypt64BitDown(curBlock);
|
||||||
|
}
|
||||||
|
|
||||||
|
len = (data >> 12) + 3;
|
||||||
|
offset = (data & 0xFFF);
|
||||||
|
windowOffset = (xOut - offset - 1);
|
||||||
|
|
||||||
|
for(j = 0; j < len; j++)
|
||||||
|
{
|
||||||
|
T1WriteByte((u8*)dst, xOut, T1ReadByte((u8*)dst, windowOffset));
|
||||||
|
xOut++;
|
||||||
|
windowOffset++;
|
||||||
|
|
||||||
|
xLen--;
|
||||||
|
if(xLen == 0)
|
||||||
|
goto lz77End;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
T1WriteByte((u8*)dst, xOut, T1ReadByte((u8*)curBlock, (xIn % 8)));
|
||||||
|
xOut++;
|
||||||
|
xIn++;
|
||||||
|
if((xIn % 8) == 0)
|
||||||
|
{
|
||||||
|
memcpy(curBlock, (((u8*)src) + xIn), 8);
|
||||||
|
crypt64BitDown(curBlock);
|
||||||
|
}
|
||||||
|
|
||||||
|
xLen--;
|
||||||
|
if(xLen == 0)
|
||||||
|
goto lz77End;
|
||||||
|
}
|
||||||
|
|
||||||
|
d = ((d << 1) & 0xFF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lz77End:
|
||||||
|
|
||||||
|
return dst;
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOL decryptFirmware(u8 *data)
|
||||||
|
{
|
||||||
|
u16 shifts;
|
||||||
|
u16 shift1, shift2, shift3, shift4;
|
||||||
|
u32 part1addr, part2addr, part3addr, part4addr, part5addr;
|
||||||
|
u32 part1ram, part2ram;
|
||||||
|
|
||||||
|
shifts = T1ReadWord(data, 0x14);
|
||||||
|
shift1 = (shifts & 0x7);
|
||||||
|
shift2 = ((shifts >> 3) & 0x7);
|
||||||
|
shift3 = ((shifts >> 6) & 0x7);
|
||||||
|
shift4 = ((shifts >> 9) & 0x7);
|
||||||
|
|
||||||
|
part1addr = T1ReadWord(data, 0x0C);
|
||||||
|
part1addr = (part1addr << (2+shift1));
|
||||||
|
|
||||||
|
INFO("Firmware: ARM9 boot code address: %05X\n", part1addr);
|
||||||
|
|
||||||
|
part1ram = T1ReadWord(data, 0x0E);
|
||||||
|
part1ram = (0x02800000 - (part1ram << (2+shift2)));
|
||||||
|
|
||||||
|
INFO("Firmware: ARM9 boot code RAM address: %08X\n", part1ram);
|
||||||
|
|
||||||
|
part2addr = T1ReadWord(data, 0x10);
|
||||||
|
part2addr = (part2addr << (2+shift3));
|
||||||
|
|
||||||
|
INFO("Firmware: ARM7 boot code address: %05X\n", part2addr);
|
||||||
|
|
||||||
|
part2ram = T1ReadWord(data, 0x12);
|
||||||
|
part2ram = (0x03810000 - (part2ram << (2+shift4)));
|
||||||
|
|
||||||
|
INFO("Firmware: ARM7 boot code RAM address: %08X\n", part2ram);
|
||||||
|
|
||||||
|
part3addr = T1ReadWord(data, 0x00);
|
||||||
|
part3addr = (part3addr << 3);
|
||||||
|
|
||||||
|
INFO("Firmware: ARM9 GUI code address: %05X\n", part3addr);
|
||||||
|
|
||||||
|
part4addr = T1ReadWord(data, 0x02);
|
||||||
|
part4addr = (part4addr << 3);
|
||||||
|
|
||||||
|
INFO("Firmware: ARM7 GUI code address: %05X\n", part4addr);
|
||||||
|
|
||||||
|
part5addr = T1ReadWord(data, 0x16);
|
||||||
|
part5addr = (part5addr << 3);
|
||||||
|
|
||||||
|
INFO("Firmware: data/gfx address: %05X\n", part5addr);
|
||||||
|
|
||||||
|
if(initKeycode(T1ReadLong(data, 0x08), 1, 0xC) == FALSE) return FALSE;
|
||||||
|
crypt64BitDown((u32*)&data[0x18]);
|
||||||
|
if(initKeycode(T1ReadLong(data, 0x08), 2, 0xC) == FALSE) return FALSE;
|
||||||
|
|
||||||
|
nds.FW_ARM9BootCode = (u8*)decryptFirmwareBlock("ARM9 boot code", (u32*)&data[part1addr], nds.FW_ARM9BootCodeSize);
|
||||||
|
nds.FW_ARM7BootCode = (u8*)decryptFirmwareBlock("ARM7 boot code", (u32*)&data[part2addr], nds.FW_ARM7BootCodeSize);
|
||||||
|
|
||||||
|
nds.FW_ARM9BootCodeAddr = part1ram;
|
||||||
|
nds.FW_ARM7BootCodeAddr = part2ram;
|
||||||
|
|
||||||
|
u16 crc16_header = T1ReadWord(data, 0x06);
|
||||||
|
u16 crc16_mine = getBootCodeCRC16();
|
||||||
|
if(crc16_header != crc16_mine)
|
||||||
|
{
|
||||||
|
INFO("Firmware: error: the boot code CRC16 (%04X) doesn't match the value in the firmware header (%04X).\n",
|
||||||
|
crc16_mine, crc16_header);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* u32 i;
|
||||||
|
|
||||||
|
for(i = 0; i < nds.FW_ARM9BootCodeSize; i += 4)
|
||||||
|
{
|
||||||
|
_MMU_write32(0, (part1ram + i), T1ReadLong(nds.FW_ARM9BootCode, i));
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < nds.FW_ARM7BootCodeSize; i += 4)
|
||||||
|
{
|
||||||
|
_MMU_write32(1, (part2ram + i), T1ReadLong(nds.FW_ARM7BootCode, i));
|
||||||
|
}*/
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static u32
|
static u32
|
||||||
calc_CRC16( u32 start, const u8 *data, int count) {
|
calc_CRC16( u32 start, const u8 *data, int count) {
|
||||||
int i,j;
|
int i,j;
|
||||||
|
@ -200,6 +534,9 @@ int NDS_Init( void) {
|
||||||
WIFI_SoftAP_Init(&wifiMac);
|
WIFI_SoftAP_Init(&wifiMac);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
nds.FW_ARM9BootCode = NULL;
|
||||||
|
nds.FW_ARM7BootCode = NULL;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -536,28 +873,50 @@ void NDS_Reset( void)
|
||||||
|
|
||||||
MMU_clearMem();
|
MMU_clearMem();
|
||||||
|
|
||||||
src = header->ARM9src;
|
if(CommonSettings.UseExtFirmware == true)
|
||||||
dst = header->ARM9cpy;
|
NDS_LoadFirmware(CommonSettings.Firmware);
|
||||||
|
|
||||||
for(i = 0; i < (header->ARM9binSize>>2); ++i)
|
if((CommonSettings.UseExtFirmware == true) && (CommonSettings.BootFromFirmware == true))
|
||||||
{
|
{
|
||||||
_MMU_write32<ARMCPU_ARM9>(dst, T1ReadLong(MMU.CART_ROM, src));
|
for(i = 0; i < nds.FW_ARM9BootCodeSize; i += 4)
|
||||||
dst += 4;
|
{
|
||||||
src += 4;
|
_MMU_write32(0, (nds.FW_ARM9BootCodeAddr + i), T1ReadLong(nds.FW_ARM9BootCode, i));
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < nds.FW_ARM7BootCodeSize; i += 4)
|
||||||
|
{
|
||||||
|
_MMU_write32(1, (nds.FW_ARM7BootCodeAddr + i), T1ReadLong(nds.FW_ARM7BootCode, i));
|
||||||
|
}
|
||||||
|
|
||||||
|
armcpu_init(&NDS_ARM9, nds.FW_ARM9BootCodeAddr);
|
||||||
|
armcpu_init(&NDS_ARM7, nds.FW_ARM7BootCodeAddr);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
src = header->ARM9src;
|
||||||
|
dst = header->ARM9cpy;
|
||||||
|
|
||||||
|
for(i = 0; i < (header->ARM9binSize>>2); ++i)
|
||||||
|
{
|
||||||
|
_MMU_write32<ARMCPU_ARM9>(dst, T1ReadLong(MMU.CART_ROM, src));
|
||||||
|
dst += 4;
|
||||||
|
src += 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
src = header->ARM7src;
|
||||||
|
dst = header->ARM7cpy;
|
||||||
|
|
||||||
|
for(i = 0; i < (header->ARM7binSize>>2); ++i)
|
||||||
|
{
|
||||||
|
_MMU_write32<ARMCPU_ARM7>(dst, T1ReadLong(MMU.CART_ROM, src));
|
||||||
|
dst += 4;
|
||||||
|
src += 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
armcpu_init(&NDS_ARM7, header->ARM7exe);
|
||||||
|
armcpu_init(&NDS_ARM9, header->ARM9exe);
|
||||||
}
|
}
|
||||||
|
|
||||||
src = header->ARM7src;
|
|
||||||
dst = header->ARM7cpy;
|
|
||||||
|
|
||||||
for(i = 0; i < (header->ARM7binSize>>2); ++i)
|
|
||||||
{
|
|
||||||
_MMU_write32<ARMCPU_ARM7>(dst, T1ReadLong(MMU.CART_ROM, src));
|
|
||||||
dst += 4;
|
|
||||||
src += 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
armcpu_init(&NDS_ARM7, header->ARM7exe);
|
|
||||||
armcpu_init(&NDS_ARM9, header->ARM9exe);
|
|
||||||
nds.ARM9Cycle = 0;
|
nds.ARM9Cycle = 0;
|
||||||
nds.ARM7Cycle = 0;
|
nds.ARM7Cycle = 0;
|
||||||
nds.cycles = 0;
|
nds.cycles = 0;
|
||||||
|
@ -603,15 +962,15 @@ void NDS_Reset( void)
|
||||||
//_MMU_write32[ARMCPU_ARM9](0x02007FFC, 0xE92D4030);
|
//_MMU_write32[ARMCPU_ARM9](0x02007FFC, 0xE92D4030);
|
||||||
|
|
||||||
//ARM7 BIOS IRQ HANDLER
|
//ARM7 BIOS IRQ HANDLER
|
||||||
#ifdef USE_REAL_BIOS
|
if(CommonSettings.UseExtBIOS == true)
|
||||||
inf = fopen("BiosNds7.ROM","rb");
|
inf = fopen(CommonSettings.ARM7BIOS,"rb");
|
||||||
#else
|
else
|
||||||
inf = NULL;
|
inf = NULL;
|
||||||
#endif
|
|
||||||
if(inf) {
|
if(inf) {
|
||||||
fread(MMU.ARM7_BIOS,1,16384,inf);
|
fread(MMU.ARM7_BIOS,1,16384,inf);
|
||||||
fclose(inf);
|
fclose(inf);
|
||||||
NDS_ARM7.swi_tab = 0;
|
if(CommonSettings.SWIFromBIOS == true) NDS_ARM7.swi_tab = 0;
|
||||||
INFO("ARM7 BIOS is loaded.\n");
|
INFO("ARM7 BIOS is loaded.\n");
|
||||||
} else {
|
} else {
|
||||||
NDS_ARM7.swi_tab = ARM7_swi_tab;
|
NDS_ARM7.swi_tab = ARM7_swi_tab;
|
||||||
|
@ -627,16 +986,16 @@ void NDS_Reset( void)
|
||||||
}
|
}
|
||||||
|
|
||||||
//ARM9 BIOS IRQ HANDLER
|
//ARM9 BIOS IRQ HANDLER
|
||||||
#ifdef USE_REAL_BIOS
|
if(CommonSettings.UseExtBIOS == true)
|
||||||
inf = fopen("BiosNds9.ROM","rb");
|
inf = fopen(CommonSettings.ARM9BIOS,"rb");
|
||||||
#else
|
else
|
||||||
inf = NULL;
|
inf = NULL;
|
||||||
//memcpy(ARM9Mem.ARM9_BIOS + 0x20, gba_header_data_0x04, 156);
|
//memcpy(ARM9Mem.ARM9_BIOS + 0x20, gba_header_data_0x04, 156);
|
||||||
#endif
|
|
||||||
if(inf) {
|
if(inf) {
|
||||||
fread(ARM9Mem.ARM9_BIOS,1,4096,inf);
|
fread(ARM9Mem.ARM9_BIOS,1,4096,inf);
|
||||||
fclose(inf);
|
fclose(inf);
|
||||||
NDS_ARM9.swi_tab = 0;
|
if(CommonSettings.SWIFromBIOS == true) NDS_ARM9.swi_tab = 0;
|
||||||
INFO("ARM9 BIOS is loaded.\n");
|
INFO("ARM9 BIOS is loaded.\n");
|
||||||
} else {
|
} else {
|
||||||
NDS_ARM9.swi_tab = ARM9_swi_tab;
|
NDS_ARM9.swi_tab = ARM9_swi_tab;
|
||||||
|
@ -1024,6 +1383,13 @@ int NDS_LoadFirmware(const char *filename)
|
||||||
i = fread(MMU.fw.data, size, 1, file);
|
i = fread(MMU.fw.data, size, 1, file);
|
||||||
fclose(file);
|
fclose(file);
|
||||||
|
|
||||||
|
INFO("Firmware: decrypting NDS firmware %s...\n", filename);
|
||||||
|
|
||||||
|
if(decryptFirmware(MMU.fw.data) == FALSE)
|
||||||
|
INFO("Firmware: decryption failed.\n");
|
||||||
|
else
|
||||||
|
INFO("Firmware: decryption successful.\n");
|
||||||
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -124,6 +124,13 @@ typedef struct
|
||||||
BOOL isTouch;
|
BOOL isTouch;
|
||||||
u16 pad;
|
u16 pad;
|
||||||
|
|
||||||
|
u8 *FW_ARM9BootCode;
|
||||||
|
u8 *FW_ARM7BootCode;
|
||||||
|
u32 FW_ARM9BootCodeAddr;
|
||||||
|
u32 FW_ARM7BootCodeAddr;
|
||||||
|
u32 FW_ARM9BootCodeSize;
|
||||||
|
u32 FW_ARM7BootCodeSize;
|
||||||
|
|
||||||
BOOL sleeping;
|
BOOL sleeping;
|
||||||
|
|
||||||
//this is not essential NDS runtime state.
|
//this is not essential NDS runtime state.
|
||||||
|
@ -277,8 +284,25 @@ inline u32 NDS_exec(s32 nb) { return NDS_exec<false>(nb); }
|
||||||
extern struct TCommonSettings {
|
extern struct TCommonSettings {
|
||||||
TCommonSettings()
|
TCommonSettings()
|
||||||
: HighResolutionInterpolateColor(true)
|
: HighResolutionInterpolateColor(true)
|
||||||
{}
|
, UseExtBIOS(false)
|
||||||
|
, SWIFromBIOS(false)
|
||||||
|
, UseExtFirmware(false)
|
||||||
|
, BootFromFirmware(false)
|
||||||
|
{
|
||||||
|
strcpy(ARM9BIOS, "biosnds9.bin");
|
||||||
|
strcpy(ARM7BIOS, "biosnds7.bin");
|
||||||
|
strcpy(Firmware, "firmware.bin");
|
||||||
|
}
|
||||||
bool HighResolutionInterpolateColor;
|
bool HighResolutionInterpolateColor;
|
||||||
|
|
||||||
|
bool UseExtBIOS;
|
||||||
|
char ARM9BIOS[256];
|
||||||
|
char ARM7BIOS[256];
|
||||||
|
bool SWIFromBIOS;
|
||||||
|
|
||||||
|
bool UseExtFirmware;
|
||||||
|
char Firmware[256];
|
||||||
|
bool BootFromFirmware;
|
||||||
} CommonSettings;
|
} CommonSettings;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1437,6 +1437,15 @@ int WINAPI WinMain (HINSTANCE hThisInstance,
|
||||||
sndvolume = GetPrivateProfileInt("Sound","Volume",100, IniName);
|
sndvolume = GetPrivateProfileInt("Sound","Volume",100, IniName);
|
||||||
SPU_SetVolume(sndvolume);
|
SPU_SetVolume(sndvolume);
|
||||||
|
|
||||||
|
CommonSettings.UseExtBIOS = GetPrivateProfileInt("BIOS", "UseExtBIOS", false, IniName);
|
||||||
|
GetPrivateProfileString("BIOS", "ARM9BIOSFile", "bios9.bin", CommonSettings.ARM9BIOS, 256, IniName);
|
||||||
|
GetPrivateProfileString("BIOS", "ARM7BIOSFile", "bios7.bin", CommonSettings.ARM7BIOS, 256, IniName);
|
||||||
|
CommonSettings.SWIFromBIOS = GetPrivateProfileInt("BIOS", "SWIFromBIOS", false, IniName);
|
||||||
|
|
||||||
|
CommonSettings.UseExtFirmware = GetPrivateProfileInt("Firmware", "UseExtFirmware", false, IniName);
|
||||||
|
GetPrivateProfileString("Firmware", "FirmwareFile", "firmware.bin", CommonSettings.Firmware, 256, IniName);
|
||||||
|
CommonSettings.BootFromFirmware = GetPrivateProfileInt("Firmware", "BootFromFirmware", false, IniName);
|
||||||
|
|
||||||
/* Read the firmware settings from the init file */
|
/* Read the firmware settings from the init file */
|
||||||
win_fw_config.fav_colour = GetPrivateProfileInt("Firmware","favColor", 10, IniName);
|
win_fw_config.fav_colour = GetPrivateProfileInt("Firmware","favColor", 10, IniName);
|
||||||
win_fw_config.birth_month = GetPrivateProfileInt("Firmware","bMonth", 7, IniName);
|
win_fw_config.birth_month = GetPrivateProfileInt("Firmware","bMonth", 7, IniName);
|
||||||
|
@ -2944,7 +2953,167 @@ LRESULT CALLBACK EmulationSettingsDlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, L
|
||||||
switch(uMsg)
|
switch(uMsg)
|
||||||
{
|
{
|
||||||
case WM_INITDIALOG:
|
case WM_INITDIALOG:
|
||||||
break;
|
{
|
||||||
|
HWND cur;
|
||||||
|
|
||||||
|
cur = GetDlgItem(hDlg, IDC_CHECKBOX_DEBUGGERMODE);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
|
||||||
|
CheckDlgButton(hDlg, IDC_USEEXTBIOS, ((CommonSettings.UseExtBIOS == true) ? BST_CHECKED : BST_UNCHECKED));
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM9BIOS);
|
||||||
|
SetWindowText(cur, CommonSettings.ARM9BIOS);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM7BIOS);
|
||||||
|
SetWindowText(cur, CommonSettings.ARM7BIOS);
|
||||||
|
CheckDlgButton(hDlg, IDC_BIOSSWIS, ((CommonSettings.SWIFromBIOS == true) ? BST_CHECKED : BST_UNCHECKED));
|
||||||
|
|
||||||
|
if(CommonSettings.UseExtBIOS == false)
|
||||||
|
{
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM9BIOS);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM9BIOSBROWSE);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM7BIOS);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM7BIOSBROWSE);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_BIOSSWIS);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
CheckDlgButton(hDlg, IDC_USEEXTFIRMWARE, ((CommonSettings.UseExtFirmware == true) ? BST_CHECKED : BST_UNCHECKED));
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWARE);
|
||||||
|
SetWindowText(cur, CommonSettings.Firmware);
|
||||||
|
CheckDlgButton(hDlg, IDC_FIRMWAREBOOT, ((CommonSettings.BootFromFirmware == true) ? BST_CHECKED : BST_UNCHECKED));
|
||||||
|
|
||||||
|
if(CommonSettings.UseExtFirmware == false)
|
||||||
|
{
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWARE);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWAREBROWSE);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWAREBOOT);
|
||||||
|
EnableWindow(cur, FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
case WM_COMMAND:
|
||||||
|
{
|
||||||
|
switch(LOWORD(wParam))
|
||||||
|
{
|
||||||
|
case IDOK:
|
||||||
|
{
|
||||||
|
int val = 0;
|
||||||
|
|
||||||
|
if(romloaded)
|
||||||
|
val = MessageBox(hDlg, "The current ROM needs to be reset to apply changes.\nReset now ?", "DeSmuME", (MB_YESNO | MB_ICONQUESTION));
|
||||||
|
|
||||||
|
if((!romloaded) || (val == IDYES))
|
||||||
|
{
|
||||||
|
HWND cur;
|
||||||
|
|
||||||
|
CommonSettings.UseExtBIOS = IsDlgButtonChecked(hDlg, IDC_USEEXTBIOS);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM9BIOS);
|
||||||
|
GetWindowText(cur, CommonSettings.ARM9BIOS, 256);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM7BIOS);
|
||||||
|
GetWindowText(cur, CommonSettings.ARM7BIOS, 256);
|
||||||
|
CommonSettings.SWIFromBIOS = IsDlgButtonChecked(hDlg, IDC_BIOSSWIS);
|
||||||
|
|
||||||
|
CommonSettings.UseExtFirmware = IsDlgButtonChecked(hDlg, IDC_USEEXTFIRMWARE);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWARE);
|
||||||
|
GetWindowText(cur, CommonSettings.Firmware, 256);
|
||||||
|
CommonSettings.BootFromFirmware = IsDlgButtonChecked(hDlg, IDC_FIRMWAREBOOT);
|
||||||
|
|
||||||
|
WritePrivateProfileInt("BIOS", "UseExtBIOS", ((CommonSettings.UseExtBIOS == true) ? 1 : 0), IniName);
|
||||||
|
WritePrivateProfileString("BIOS", "ARM9BIOSFile", CommonSettings.ARM9BIOS, IniName);
|
||||||
|
WritePrivateProfileString("BIOS", "ARM7BIOSFile", CommonSettings.ARM7BIOS, IniName);
|
||||||
|
WritePrivateProfileInt("BIOS", "SWIFromBIOS", ((CommonSettings.SWIFromBIOS == true) ? 1 : 0), IniName);
|
||||||
|
|
||||||
|
WritePrivateProfileInt("Firmware", "UseExtFirmware", ((CommonSettings.UseExtFirmware == true) ? 1 : 0), IniName);
|
||||||
|
WritePrivateProfileString("Firmware", "FirmwareFile", CommonSettings.Firmware, IniName);
|
||||||
|
WritePrivateProfileInt("Firmware", "BootFromFirmware", ((CommonSettings.BootFromFirmware == true) ? 1 : 0), IniName);
|
||||||
|
|
||||||
|
if(romloaded)
|
||||||
|
{
|
||||||
|
CheatsSearchReset();
|
||||||
|
NDS_Reset();
|
||||||
|
frameCounter = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case IDCANCEL:
|
||||||
|
{
|
||||||
|
EndDialog(hDlg, TRUE);
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
case IDC_USEEXTBIOS:
|
||||||
|
{
|
||||||
|
HWND cur;
|
||||||
|
BOOL enable = IsDlgButtonChecked(hDlg, IDC_USEEXTBIOS);
|
||||||
|
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM9BIOS);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM9BIOSBROWSE);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM7BIOS);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_ARM7BIOSBROWSE);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_BIOSSWIS);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
case IDC_USEEXTFIRMWARE:
|
||||||
|
{
|
||||||
|
HWND cur;
|
||||||
|
BOOL enable = IsDlgButtonChecked(hDlg, IDC_USEEXTFIRMWARE);
|
||||||
|
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWARE);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWAREBROWSE);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
cur = GetDlgItem(hDlg, IDC_FIRMWAREBOOT);
|
||||||
|
EnableWindow(cur, enable);
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
case IDC_ARM9BIOSBROWSE:
|
||||||
|
case IDC_ARM7BIOSBROWSE:
|
||||||
|
case IDC_FIRMWAREBROWSE:
|
||||||
|
{
|
||||||
|
char fileName[256] = "";
|
||||||
|
OPENFILENAME ofn;
|
||||||
|
|
||||||
|
ZeroMemory(&ofn, sizeof(ofn));
|
||||||
|
ofn.lStructSize = sizeof(ofn);
|
||||||
|
ofn.hwndOwner = hDlg;
|
||||||
|
ofn.lpstrFilter = "Binary file (*.bin)\0*.bin\0ROM file (*.rom)\0*.rom\0Any file(*.*)\0*.*\0\0";
|
||||||
|
ofn.nFilterIndex = 1;
|
||||||
|
ofn.lpstrFile = fileName;
|
||||||
|
ofn.nMaxFile = 256;
|
||||||
|
ofn.lpstrDefExt = "bin";
|
||||||
|
ofn.Flags = OFN_NOCHANGEDIR;
|
||||||
|
|
||||||
|
if(GetOpenFileName(&ofn))
|
||||||
|
{
|
||||||
|
HWND cur;
|
||||||
|
|
||||||
|
switch(LOWORD(wParam))
|
||||||
|
{
|
||||||
|
case IDC_ARM9BIOSBROWSE: cur = GetDlgItem(hDlg, IDC_ARM9BIOS); break;
|
||||||
|
case IDC_ARM7BIOSBROWSE: cur = GetDlgItem(hDlg, IDC_ARM7BIOS); break;
|
||||||
|
case IDC_FIRMWAREBROWSE: cur = GetDlgItem(hDlg, IDC_FIRMWARE); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
SetWindowText(cur, fileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
Loading…
Reference in New Issue