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
|
@ -284,7 +284,7 @@ class CpuInitializer
|
||||||
public:
|
public:
|
||||||
std::unique_ptr<CpuType> MyCpu;
|
std::unique_ptr<CpuType> MyCpu;
|
||||||
ScopedExcept ExThrown;
|
ScopedExcept ExThrown;
|
||||||
|
|
||||||
CpuInitializer();
|
CpuInitializer();
|
||||||
virtual ~CpuInitializer() throw();
|
virtual ~CpuInitializer() throw();
|
||||||
|
|
||||||
|
@ -392,7 +392,7 @@ void SysMainMemory::ReserveAll()
|
||||||
m_ee.Reserve();
|
m_ee.Reserve();
|
||||||
m_iop.Reserve();
|
m_iop.Reserve();
|
||||||
m_vu.Reserve();
|
m_vu.Reserve();
|
||||||
|
|
||||||
reserveNewVif(0);
|
reserveNewVif(0);
|
||||||
reserveNewVif(1);
|
reserveNewVif(1);
|
||||||
}
|
}
|
||||||
|
@ -444,7 +444,7 @@ void SysMainMemory::DecommitAll()
|
||||||
|
|
||||||
closeNewVif(0);
|
closeNewVif(0);
|
||||||
closeNewVif(1);
|
closeNewVif(1);
|
||||||
|
|
||||||
vtlb_Core_Free();
|
vtlb_Core_Free();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -653,20 +653,26 @@ u8* SysMmapEx(uptr base, u32 size, uptr bounds, const char *caller)
|
||||||
return Mem;
|
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
|
// 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
|
// falling back on the CRC checksum of the ELF binary if the PS2 software being run is
|
||||||
// homebrew or some other serial-less item.
|
// homebrew or some other serial-less item.
|
||||||
wxString SysGetDiscID()
|
wxString SysGetDiscID()
|
||||||
{
|
{
|
||||||
if( !DiscSerial.IsEmpty() ) return DiscSerial;
|
if( !DiscSerial.IsEmpty() ) return DiscSerial;
|
||||||
|
|
||||||
if( !ElfCRC )
|
if( !ElfCRC )
|
||||||
{
|
{
|
||||||
// FIXME: system is currently running the BIOS, so it should return a serial based on
|
// system is currently running the BIOS
|
||||||
// the BIOS being run (either a checksum of the BIOS roms, and/or a string based on BIOS
|
return SysGetBiosDiscID();
|
||||||
// region and revision).
|
|
||||||
|
|
||||||
return wxEmptyString;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return pxsFmt( L"%08x", ElfCRC );
|
return pxsFmt( L"%08x", ElfCRC );
|
||||||
|
|
|
@ -87,20 +87,20 @@ namespace HostMemoryMap
|
||||||
// microVU0 recompiler code cache area (64mb)
|
// microVU0 recompiler code cache area (64mb)
|
||||||
static const uptr mVU1rec = 0x40000000;
|
static const uptr mVU1rec = 0x40000000;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
// SysMainMemory
|
// SysMainMemory
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
// This class provides the main memory for the virtual machines.
|
// This class provides the main memory for the virtual machines.
|
||||||
class SysMainMemory
|
class SysMainMemory
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
eeMemoryReserve m_ee;
|
eeMemoryReserve m_ee;
|
||||||
iopMemoryReserve m_iop;
|
iopMemoryReserve m_iop;
|
||||||
vuMemoryReserve m_vu;
|
vuMemoryReserve m_vu;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SysMainMemory();
|
SysMainMemory();
|
||||||
virtual ~SysMainMemory() throw();
|
virtual ~SysMainMemory() throw();
|
||||||
|
@ -179,6 +179,7 @@ extern u8 *SysMmapEx(uptr base, u32 size, uptr bounds, const char *caller="Unnam
|
||||||
extern void vSyncDebugStuff( uint frame );
|
extern void vSyncDebugStuff( uint frame );
|
||||||
extern void NTFS_CompressFile( const wxString& file, bool compressStatus=true );
|
extern void NTFS_CompressFile( const wxString& file, bool compressStatus=true );
|
||||||
|
|
||||||
|
extern wxString SysGetBiosDiscID();
|
||||||
extern wxString SysGetDiscID();
|
extern wxString SysGetDiscID();
|
||||||
|
|
||||||
extern SysMainMemory& GetVmMemory();
|
extern SysMainMemory& GetVmMemory();
|
||||||
|
|
|
@ -358,10 +358,16 @@ static void _ApplySettings( const Pcsx2Config& src, Pcsx2Config& fixup )
|
||||||
wxString gameCompat;
|
wxString gameCompat;
|
||||||
wxString gameMemCardFilter;
|
wxString gameMemCardFilter;
|
||||||
|
|
||||||
if (ElfCRC) gameCRC.Printf( L"%8.8x", ElfCRC );
|
// The CRC can be known before the game actually starts (at the bios), so when
|
||||||
if (!DiscSerial.IsEmpty()) gameSerial = L" [" + DiscSerial + L"]";
|
// 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 );
|
const bool verbose( newGameKey != curGameKey );
|
||||||
SetupPatchesCon(verbose);
|
SetupPatchesCon(verbose);
|
||||||
|
|
||||||
|
@ -442,6 +448,11 @@ static void _ApplySettings( const Pcsx2Config& src, Pcsx2Config& fixup )
|
||||||
wxString consoleTitle = gameName + gameSerial;
|
wxString consoleTitle = gameName + gameSerial;
|
||||||
consoleTitle += L" [" + gameCRC.MakeUpper() + L"]" + gameCompat + gameFixes + gamePatch + gameCheats + gameWsHacks;
|
consoleTitle += L" [" + gameCRC.MakeUpper() + L"]" + gameCompat + gameFixes + gamePatch + gameCheats + gameWsHacks;
|
||||||
Console.SetTitle(consoleTitle);
|
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
|
// FIXME: This function is not for general consumption. Its only consumer (and
|
||||||
|
|
|
@ -155,7 +155,7 @@ static void LoadBiosVersion( pxInputStream& fp, u32& version, wxString& descript
|
||||||
throw Exception::BadStream( fp.GetStreamName() )
|
throw Exception::BadStream( fp.GetStreamName() )
|
||||||
.SetDiagMsg(L"BIOS version check failed: 'ROMDIR' tag could not be found.")
|
.SetDiagMsg(L"BIOS version check failed: 'ROMDIR' tag could not be found.")
|
||||||
.SetUserMsg(_("The selected BIOS file is not a valid PS2 BIOS. Please re-configure."));
|
.SetUserMsg(_("The selected BIOS file is not a valid PS2 BIOS. Please re-configure."));
|
||||||
|
|
||||||
wxFileOffset fileSize = fp.Length();
|
wxFileOffset fileSize = fp.Length();
|
||||||
if (fileSize < (int)fileOffset)
|
if (fileSize < (int)fileOffset)
|
||||||
{
|
{
|
||||||
|
@ -325,7 +325,7 @@ bool IsBIOS(const wxString& filename, wxString& description)
|
||||||
{
|
{
|
||||||
wxFileName Bios( g_Conf->Folders.Bios + filename );
|
wxFileName Bios( g_Conf->Folders.Bios + filename );
|
||||||
pxInputStream inway( filename, new wxFFileInputStream( filename ) );
|
pxInputStream inway( filename, new wxFFileInputStream( filename ) );
|
||||||
|
|
||||||
if (!inway.IsOk()) return false;
|
if (!inway.IsOk()) return false;
|
||||||
// FPS2BIOS is smaller and of variable size
|
// FPS2BIOS is smaller and of variable size
|
||||||
//if (inway.Length() < 512*1024) return false;
|
//if (inway.Length() < 512*1024) return false;
|
||||||
|
|
Loading…
Reference in New Issue