patches/cheats: document "place" value and use it explicitly

This commit doesn't change any behavior, but documents the "places" value
of the patch structure ("place" is 1 in patch=1,... and 0 in patch=0,...)
and also uses an enum to make its use explicit.
This commit is contained in:
Avi Halachmi (:avih) 2016-07-27 13:38:25 +03:00
parent 67aee8a19c
commit eb1e890278
4 changed files with 37 additions and 15 deletions

View File

@ -362,7 +362,7 @@ namespace PatchFunc
}
// This is for applying patches directly to memory
void ApplyPatch(int place)
void ApplyPatch(patch_place_type place)
{
for (int i = 0; i < patchnumber; i++)
{
@ -372,7 +372,7 @@ void ApplyPatch(int place)
}
// This is for applying cheats directly to memory
void ApplyCheat(int place)
void ApplyCheat(patch_place_type place)
{
for (int i = 0; i < cheatnumber; i++)
{

View File

@ -36,6 +36,28 @@ enum patch_data_type {
EXTENDED_T
};
// "place" is the first number at a pnach line (patch=<place>,...), e.g.:
// - patch=1,EE,001110e0,word,00000000 <-- place is 1
// - patch=0,EE,0010BC88,word,48468800 <-- place is 0
// In PCSX2 it indicates how/when/where the patch line should be applied. If
// place is not one of the supported values then the patch line is never applied.
// PCSX2 currently supports the following values:
// 0 - apply the patch line once on game boot/startup
// 1 - apply the patch line continuously (technically - on every vsync)
// Note:
// - while it may seem that a value of 1 does the same as 0, but also later
// continues to apply the patch on every vsync - it's not.
// The current (and past) behavior is that these patches are applied at different
// places at the code, and it's possible, depending on circumstances, that 0 patches
// will get applied before the first vsync and therefore earlier than 1 patches.
// - There's no "place" value which indicates to apply both once on startup
// and then also continuously, however such behavior can be achieved by
// duplicating the line where one has a 0 place and the other has a 1 place.
enum patch_place_type {
PPT_ONCE_ON_LOAD = 0,
PPT_CONTINUOUSLY = 1
};
typedef void PATCHTABLEFUNC( const wxString& text1, const wxString& text2 );
struct IniPatch
@ -67,8 +89,8 @@ extern void inifile_trim(wxString& buffer);
extern int InitPatches(const wxString& name, const Game_Data& game);
extern int AddPatch(int Mode, int Place, int Address, int Size, u64 data);
extern void ResetPatch(void);
extern void ApplyPatch(int place = 1);
extern void ApplyCheat(int place = 1);
extern void ApplyPatch(patch_place_type place);
extern void ApplyCheat(patch_place_type place);
extern void _ApplyPatch(IniPatch *p);
extern const IConsoleWriter *PatchesCon;

View File

@ -228,9 +228,9 @@ void SysCoreThread::DoCpuReset()
//
void SysCoreThread::VsyncInThread()
{
if (EmuConfig.EnablePatches) ApplyPatch();
if (EmuConfig.EnableCheats) ApplyCheat();
if (EmuConfig.EnableWideScreenPatches) ApplyCheat();
if (EmuConfig.EnablePatches) ApplyPatch(PPT_CONTINUOUSLY);
if (EmuConfig.EnableCheats) ApplyCheat(PPT_CONTINUOUSLY);
if (EmuConfig.EnableWideScreenPatches) ApplyCheat(PPT_CONTINUOUSLY);
}
void SysCoreThread::GameStartingInThread()
@ -241,8 +241,8 @@ void SysCoreThread::GameStartingInThread()
symbolMap.UpdateActiveSymbols();
sApp.PostAppMethod(&Pcsx2App::resetDebugger);
if (EmuConfig.EnablePatches) ApplyPatch(0);
if (EmuConfig.EnableCheats) ApplyCheat(0);
if (EmuConfig.EnablePatches) ApplyPatch(PPT_ONCE_ON_LOAD);
if (EmuConfig.EnableCheats) ApplyCheat(PPT_ONCE_ON_LOAD);
}
bool SysCoreThread::StateCheckInThread()

View File

@ -1618,8 +1618,8 @@ static void __fastcall recRecompile( const u32 startpc )
// First tentative was to call eeGameStarting directly (not through the
// recompiler) but it crashes some games (GT4, DMC3). It is either a
// thread issue or linked to the various components reset.
if (EmuConfig.EnablePatches) ApplyPatch(0);
if (EmuConfig.EnableCheats) ApplyCheat(0);
if (EmuConfig.EnablePatches) ApplyPatch(PPT_ONCE_ON_LOAD);
if (EmuConfig.EnableCheats) ApplyCheat(PPT_ONCE_ON_LOAD);
}
g_branch = 0;