mirror of https://github.com/PCSX2/pcsx2.git
game settings/patches: don't apply acidentally to the bios
While c782b62
added much more reliable game game startup detection, the
settings system did not yet gain that knowledge, but typically that's OK.
Typically the settings (and patches) are loaded according to the current
CRC, which happens once on bios boot (with general settings) and then again
when the game starts, which includes game-specific fixes, patches, etc.
However, if the setting are changed (and therefore also applied) after
the game CRC is known but before the game starts, such as if the user
presses Tab to change framelimiter while at the bios, then until now it
was accidentally applying the game's settings while still at the bios.
This commit makes the settings routine know whether or not the game actually
started, and apply the generic/game settings accordingly.
This commit is contained in:
parent
c782b6222c
commit
e8e6d3bc77
|
@ -653,6 +653,15 @@ u8* SysMmapEx(uptr base, u32 size, uptr bounds, const char *caller)
|
|||
return Mem;
|
||||
}
|
||||
|
||||
wxString SysGetBiosDiscID()
|
||||
{
|
||||
// FIXME: we should return a serial based on
|
||||
// the BIOS being run (either a checksum of the BIOS roms, and/or a string based on BIOS
|
||||
// region and revision).
|
||||
|
||||
return wxEmptyString;
|
||||
}
|
||||
|
||||
// This function always returns a valid DiscID -- using the Sony serial when possible, and
|
||||
// falling back on the CRC checksum of the ELF binary if the PS2 software being run is
|
||||
// homebrew or some other serial-less item.
|
||||
|
@ -662,11 +671,8 @@ wxString SysGetDiscID()
|
|||
|
||||
if( !ElfCRC )
|
||||
{
|
||||
// FIXME: system is currently running the BIOS, so it should return a serial based on
|
||||
// the BIOS being run (either a checksum of the BIOS roms, and/or a string based on BIOS
|
||||
// region and revision).
|
||||
|
||||
return wxEmptyString;
|
||||
// system is currently running the BIOS
|
||||
return SysGetBiosDiscID();
|
||||
}
|
||||
|
||||
return pxsFmt( L"%08x", ElfCRC );
|
||||
|
|
|
@ -179,6 +179,7 @@ extern u8 *SysMmapEx(uptr base, u32 size, uptr bounds, const char *caller="Unnam
|
|||
extern void vSyncDebugStuff( uint frame );
|
||||
extern void NTFS_CompressFile( const wxString& file, bool compressStatus=true );
|
||||
|
||||
extern wxString SysGetBiosDiscID();
|
||||
extern wxString SysGetDiscID();
|
||||
|
||||
extern SysMainMemory& GetVmMemory();
|
||||
|
|
|
@ -358,10 +358,16 @@ static void _ApplySettings( const Pcsx2Config& src, Pcsx2Config& fixup )
|
|||
wxString gameCompat;
|
||||
wxString gameMemCardFilter;
|
||||
|
||||
if (ElfCRC) gameCRC.Printf( L"%8.8x", ElfCRC );
|
||||
if (!DiscSerial.IsEmpty()) gameSerial = L" [" + DiscSerial + L"]";
|
||||
// The CRC can be known before the game actually starts (at the bios), so when
|
||||
// we have the CRC but we're still at the bios and the settings are changed
|
||||
// (e.g. the user presses TAB to speed up emulation), we don't want to apply the
|
||||
// settings as if the game is already running (title, loadeding patches, etc).
|
||||
bool ingame = (ElfCRC && (g_GameLoading || g_GameStarted));
|
||||
if (ingame)
|
||||
gameCRC.Printf( L"%8.8x", ElfCRC );
|
||||
if (ingame && !DiscSerial.IsEmpty()) gameSerial = L" [" + DiscSerial + L"]";
|
||||
|
||||
const wxString newGameKey( SysGetDiscID() );
|
||||
const wxString newGameKey(ingame ? SysGetDiscID() : SysGetBiosDiscID());
|
||||
const bool verbose( newGameKey != curGameKey );
|
||||
SetupPatchesCon(verbose);
|
||||
|
||||
|
@ -442,6 +448,11 @@ static void _ApplySettings( const Pcsx2Config& src, Pcsx2Config& fixup )
|
|||
wxString consoleTitle = gameName + gameSerial;
|
||||
consoleTitle += L" [" + gameCRC.MakeUpper() + L"]" + gameCompat + gameFixes + gamePatch + gameCheats + gameWsHacks;
|
||||
Console.SetTitle(consoleTitle);
|
||||
// It's possible then when we're booting, the bios loader will set a more detailed title
|
||||
// with region, version, etc, thus overriding our patches status at the title. That's OK. Those
|
||||
// users which want to know the status of the patches at the bios can check the console content.
|
||||
// However, the bios loader sets the title once, so if any settings are changed and we're called
|
||||
// (e.g. if the user presses tab to change the limiter), then the title will be set to consoleTitle.
|
||||
}
|
||||
|
||||
// FIXME: This function is not for general consumption. Its only consumer (and
|
||||
|
|
Loading…
Reference in New Issue