make sure Key1 data is loaded right even if the BIOSes aren't loaded at the time

This commit is contained in:
Arisotura 2022-01-04 11:27:54 +01:00
parent b0a22e4ce9
commit 5c924c9f01
2 changed files with 19 additions and 5 deletions

View File

@ -747,6 +747,9 @@ void DoSavestate(Savestate* file)
//void LoadROMCommon(const char *sram) //void LoadROMCommon(const char *sram)
bool LoadROM(const u8* romdata, u32 romlen) bool LoadROM(const u8* romdata, u32 romlen)
{ {
if (CartInserted)
EjectCart();
CartROMSize = 0x200; CartROMSize = 0x200;
while (CartROMSize < romlen) while (CartROMSize < romlen)
CartROMSize <<= 1; CartROMSize <<= 1;

View File

@ -132,13 +132,24 @@ void Key1_ApplyKeycode(u32* keycode, u32 mod)
} }
} }
void Key1_LoadKeyBuf(bool dsi)
{
// it is possible that this gets called before the BIOSes are loaded
// so we will read from the BIOS files directly
std::string path = Platform::GetConfigString(dsi ? Platform::DSi_BIOS7Path : Platform::BIOS7Path);
FILE* f = Platform::OpenLocalFile(path, "rb");
if (f)
{
fseek(f, dsi ? 0xC6D0 : 0x0030, SEEK_SET);
fread(Key1_KeyBuf, 0x1048, 1, f);
fclose(f);
}
}
void Key1_InitKeycode(bool dsi, u32 idcode, u32 level, u32 mod) void Key1_InitKeycode(bool dsi, u32 idcode, u32 level, u32 mod)
{ {
// TODO: source the key data from different possible places Key1_LoadKeyBuf(dsi);
if (dsi && NDS::ConsoleType==1)
memcpy(Key1_KeyBuf, &DSi::ARM7iBIOS[0xC6D0], 0x1048); // hax
else
memcpy(Key1_KeyBuf, &NDS::ARM7BIOS[0x30], 0x1048); // hax
u32 keycode[3] = {idcode, idcode>>1, idcode<<1}; u32 keycode[3] = {idcode, idcode>>1, idcode<<1};
if (level >= 1) Key1_ApplyKeycode(keycode, mod); if (level >= 1) Key1_ApplyKeycode(keycode, mod);