make sure Key1 data is loaded right even if the BIOSes aren't loaded at the time
This commit is contained in:
parent
b0a22e4ce9
commit
5c924c9f01
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue