mirror of https://github.com/PCSX2/pcsx2.git
-Updates to the configuration dialogues -Removed Fastbranches hack
git-svn-id: http://pcsx2-playground.googlecode.com/svn/trunk@367 a6443dda-0b58-4228-96e9-037be469359c
This commit is contained in:
parent
db67ecb03c
commit
2b8f13e8c8
|
@ -78,7 +78,6 @@ void CombinePaths( char* dest, const char* srcPath, const char* srcFile );
|
|||
#define CHECK_EE_IOP_EXTRA (Config.Hacks & 0x20)
|
||||
#define CHECK_UNDERFLOW (!(Config.Hacks & 0x8))
|
||||
//#define CHECK_DENORMALS ((Config.Hacks & 0x400) ? 0xffc0 : 0x7f80) //If enabled, Denormals are Zero for the recs and flush to zero is enabled as well
|
||||
#define CHECK_FASTBRANCHES (Config.Hacks & 0x80)
|
||||
#define CHECK_VU_EXTRA_FLAGS (!(Config.Hacks & 0x100)) // Sets correct flags in the VU recs
|
||||
#define CHECK_FPU_EXTRA_FLAGS (!(Config.Hacks & 0x200)) // Sets correct flags in the FPU recs
|
||||
#define CHECK_ESCAPE_HACK (Config.Hacks & 0x400)
|
||||
|
|
|
@ -56,7 +56,7 @@ BOOL CALLBACK CpuDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
|||
Static_SetText(GetDlgItem(hW, IDC_CPU_VU0REC), _("VU0rec - enable recompiler for VU0 unit"));
|
||||
Static_SetText(GetDlgItem(hW, IDC_CPU_VU1REC), _("VU1rec - enable recompiler for VU1 unit"));
|
||||
Static_SetText(GetDlgItem(hW, IDC_CPU_GSMULTI), _("Multi threaded GS mode (MTGS)\n(faster on dual core/HT procs, requires pcsx2 restart)"));
|
||||
Static_SetText(GetDlgItem(hW, IDC_CPU_MULTI), _("Dual Core Mode (DC) - Much faster but only valid with MTGS"));
|
||||
Static_SetText(GetDlgItem(hW, IDC_CPU_MULTI), _("Dual Core Mode (DC) - Only valid with MTGS. Keeps one core busy, sometimes improving FPS. Note that this increases the heat your CPU produces, so leave it off on Notebooks."));
|
||||
Static_SetText(GetDlgItem(hW, IDC_FRAMELIMIT), _("Frame Limiting (F4 key switches the mode in-game!)"));
|
||||
Static_SetText(GetDlgItem(hW, IDC_CPU_FL_NORMAL), _("Normal - All frames are rendered as fast as possible."));
|
||||
Static_SetText(GetDlgItem(hW, IDC_CPU_FL_LIMIT), _("Limit - Force frames to normal speeds if too fast."));
|
||||
|
|
|
@ -929,7 +929,6 @@ static void HacksInit( HWND hDlg )
|
|||
if(Config.Hacks & 0x10) CheckDlgButton(hDlg, IDC_SYNCHACK2, TRUE);
|
||||
if(Config.Hacks & 0x20) CheckDlgButton(hDlg, IDC_SYNCHACK3, TRUE);
|
||||
if(Config.Hacks & 0x40) CheckDlgButton(hDlg, IDC_VU_OVERFLOWHACK, 2);
|
||||
//if(Config.Hacks & 0x80) CheckDlgButton(hDlg, IDC_FASTBRANCHES, TRUE);
|
||||
if(Config.Hacks & 0x100) CheckDlgButton(hDlg, IDC_VU_FLAGS, TRUE);
|
||||
if(Config.Hacks & 0x200) CheckDlgButton(hDlg, IDC_FPU_FLAGS, TRUE);
|
||||
if(Config.Hacks & 0x400) CheckDlgButton(hDlg, IDC_ESCHACK, TRUE);
|
||||
|
@ -947,7 +946,6 @@ static void HacksChecked( HWND hDlg )
|
|||
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_DENORMALS) ? 0x8 : 0;
|
||||
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SYNCHACK2) ? 0x10 : 0;
|
||||
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SYNCHACK3) ? 0x20 : 0;
|
||||
//Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_FASTBRANCHES) ? 0x80 : 0;
|
||||
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_VU_FLAGS) ? 0x100 : 0;
|
||||
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_FPU_FLAGS) ? 0x200 : 0;
|
||||
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_ESCHACK) ? 0x400 : 0;
|
||||
|
@ -974,7 +972,7 @@ BOOL APIENTRY HacksProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
|||
EndDialog(hDlg, FALSE);
|
||||
break;
|
||||
|
||||
case IDBUTTON1:
|
||||
case IDBUTTON1: //"compatibility" setting
|
||||
CheckDlgButton(hDlg, IDC_VU_OVERFLOWHACK, FALSE);
|
||||
CheckDlgButton(hDlg, IDC_FPU_OVERFLOWHACK, FALSE);
|
||||
CheckDlgButton(hDlg, IDC_DENORMALS, TRUE);
|
||||
|
@ -983,7 +981,6 @@ BOOL APIENTRY HacksProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
|||
CheckDlgButton(hDlg, IDC_SYNCHACK, FALSE);
|
||||
CheckDlgButton(hDlg, IDC_SYNCHACK2, FALSE);
|
||||
CheckDlgButton(hDlg, IDC_SYNCHACK3, FALSE);
|
||||
//CheckDlgButton(hDlg, IDC_FASTBRANCHES, FALSE);
|
||||
//CheckDlgButton(hDlg, IDC_SOUNDHACK, TRUE);
|
||||
//CheckDlgButton(hDlg, IDC_ESCHACK, TRUE);
|
||||
|
||||
|
@ -991,7 +988,7 @@ BOOL APIENTRY HacksProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
|||
HacksInit( hDlg );
|
||||
break;
|
||||
|
||||
case IDBUTTON2:
|
||||
case IDBUTTON2: //"speed" setting
|
||||
CheckDlgButton(hDlg, IDC_VU_OVERFLOWHACK, TRUE);
|
||||
CheckDlgButton(hDlg, IDC_FPU_OVERFLOWHACK, TRUE);
|
||||
CheckDlgButton(hDlg, IDC_DENORMALS, TRUE);
|
||||
|
@ -999,8 +996,7 @@ BOOL APIENTRY HacksProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
|||
CheckDlgButton(hDlg, IDC_FPU_FLAGS, TRUE);
|
||||
CheckDlgButton(hDlg, IDC_SYNCHACK, TRUE);
|
||||
CheckDlgButton(hDlg, IDC_SYNCHACK2, TRUE);
|
||||
CheckDlgButton(hDlg, IDC_SYNCHACK3, TRUE);
|
||||
//CheckDlgButton(hDlg, IDC_FASTBRANCHES, FALSE);
|
||||
CheckDlgButton(hDlg, IDC_SYNCHACK3, FALSE);
|
||||
CheckDlgButton(hDlg, IDC_SOUNDHACK, FALSE);
|
||||
//CheckDlgButton(hDlg, IDC_ESCHACK, TRUE);
|
||||
|
||||
|
|
|
@ -896,30 +896,33 @@ BEGIN
|
|||
LTEXT "User Name:",IDC_STATIC,7,41,38,8
|
||||
END
|
||||
|
||||
IDD_ADVANCED_OPTIONS DIALOGEX 0, 0, 231, 163
|
||||
IDD_ADVANCED_OPTIONS DIALOGEX 0, 0, 246, 270
|
||||
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||
CAPTION "Advanced Options"
|
||||
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
||||
BEGIN
|
||||
DEFPUSHBUTTON "OK",IDOK,105,142,50,14
|
||||
PUSHBUTTON "Cancel",IDCANCEL,165,142,50,14
|
||||
RADIOBUTTON "Nearest",IDC_EE_ROUNDMODE0,23,33,59,16
|
||||
RADIOBUTTON "Negative",IDC_EE_ROUNDMODE1,23,48,49,16
|
||||
RADIOBUTTON "Positive",IDC_EE_ROUNDMODE2,23,62,44,16
|
||||
RADIOBUTTON "Chop / Zero",IDC_EE_ROUNDMODE3,23,76,54,16
|
||||
GROUPBOX "Roundmode",IDC_STATIC,14,23,69,75
|
||||
GROUPBOX "Roundmode",IDC_STATIC,130,23,72,76
|
||||
GROUPBOX "EE Recs Options",IDC_STATIC,7,7,101,129
|
||||
CONTROL "Flush to Zero",IDC_EE_CHECK1,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,14,103,58,13
|
||||
CONTROL "Denormals are Zero",IDC_EE_CHECK2,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,14,117,79,13
|
||||
CONTROL "Flush to Zero",IDC_VU_CHECK1,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,130,103,58,13
|
||||
CONTROL "Denormals are Zero",IDC_VU_CHECK2,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,130,117,81,13
|
||||
GROUPBOX "VU Recs Options",IDC_STATIC,121,7,103,129
|
||||
RADIOBUTTON "Nearest",IDC_VU_ROUNDMODE0,141,35,42,12
|
||||
RADIOBUTTON "Negative",IDC_VU_ROUNDMODE1,141,50,41,12
|
||||
RADIOBUTTON "Positive",IDC_VU_ROUNDMODE2,141,65,39,12
|
||||
RADIOBUTTON "Chop / Zero",IDC_VU_ROUNDMODE3,141,79,52,12
|
||||
PUSHBUTTON "Defaults",IDDEFAULT,14,142,50,14
|
||||
DEFPUSHBUTTON "OK",IDOK,109,249,50,14
|
||||
PUSHBUTTON "Cancel",IDCANCEL,165,249,50,14
|
||||
RADIOBUTTON "Nearest",IDC_EE_ROUNDMODE0,23,129,59,16
|
||||
RADIOBUTTON "Negative",IDC_EE_ROUNDMODE1,23,143,49,16
|
||||
RADIOBUTTON "Positive",IDC_EE_ROUNDMODE2,23,159,44,16
|
||||
RADIOBUTTON "Chop / Zero",IDC_EE_ROUNDMODE3,23,172,54,16
|
||||
CONTROL "Flush to Zero",IDC_EE_CHECK1,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,14,199,58,13
|
||||
CONTROL "Denormals are Zero",IDC_EE_CHECK2,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,14,212,79,13
|
||||
CONTROL "Flush to Zero",IDC_VU_CHECK1,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,134,199,58,13
|
||||
CONTROL "Denormals are Zero",IDC_VU_CHECK2,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,134,212,81,13
|
||||
RADIOBUTTON "Nearest",IDC_VU_ROUNDMODE0,144,130,42,12
|
||||
RADIOBUTTON "Negative",IDC_VU_ROUNDMODE1,144,146,41,12
|
||||
RADIOBUTTON "Positive",IDC_VU_ROUNDMODE2,144,161,39,12
|
||||
RADIOBUTTON "Chop / Zero",IDC_VU_ROUNDMODE3,144,175,52,12
|
||||
PUSHBUTTON "Defaults",IDDEFAULT,14,249,50,14
|
||||
GROUPBOX "VU Recs Options",IDC_STATIC,125,103,114,129
|
||||
GROUPBOX "EE Recs Options",IDC_STATIC,7,103,101,129
|
||||
GROUPBOX "Roundmode",IDC_STATIC,134,119,72,76
|
||||
GROUPBOX "Roundmode",IDC_STATIC,14,119,69,75
|
||||
LTEXT "These options let you set the rounding mode of the Emotion Engine (CPU) and Vector Unit recompilers. Try changing the roundmode for EE if your game hangs, it could make it work again.",IDC_STATIC,14,18,192,37
|
||||
LTEXT " ""Flush to Zero"" and ""Denormals are Zero"" for the VU recompiler can speed games up, but they also break a few. Hit default if you are not sure what to use.",IDC_STATIC,14,54,198,31
|
||||
GROUPBOX "Help",IDC_STATIC,7,7,232,83,BS_CENTER
|
||||
END
|
||||
|
||||
|
||||
|
@ -982,13 +985,13 @@ BEGIN
|
|||
IDD_ADVANCED_OPTIONS, DIALOG
|
||||
BEGIN
|
||||
LEFTMARGIN, 7
|
||||
RIGHTMARGIN, 224
|
||||
RIGHTMARGIN, 239
|
||||
VERTGUIDE, 14
|
||||
VERTGUIDE, 23
|
||||
VERTGUIDE, 130
|
||||
VERTGUIDE, 141
|
||||
VERTGUIDE, 134
|
||||
VERTGUIDE, 144
|
||||
TOPMARGIN, 7
|
||||
BOTTOMMARGIN, 156
|
||||
BOTTOMMARGIN, 263
|
||||
HORZGUIDE, 23
|
||||
HORZGUIDE, 103
|
||||
HORZGUIDE, 117
|
||||
|
@ -1049,16 +1052,14 @@ BEGIN
|
|||
CONTROL "Disable VU Overflow Checks - *Checked = Disables overflow checks. ( Speedup! ) *Greyed = Extra overflow checks. ( Helps SPS, Slow! )",IDC_VU_OVERFLOWHACK,
|
||||
"Button",BS_AUTO3STATE | WS_TABSTOP,15,49,475,10
|
||||
CTEXT "These hacks will affect the speed of PCSX2 but possibly compromise compatibility.",IDC_HACKDESC,7,7,497,8
|
||||
CONTROL "Tighter SPU2 Sync (Dawn of Mana FMV) - a bit slower",IDC_SOUNDHACK,
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,245,421,10
|
||||
CONTROL "Tighter SPU2 Sync ( Try this if you have stuttering audio ) - a bit slower",IDC_SOUNDHACK,
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,230,421,10
|
||||
CONTROL "IOP Sync Hack (x2) - Doubles the cycle rate of the IOP. ( Speedup but breaks some games. )",IDC_SYNCHACK2,
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,176,410,10
|
||||
CONTROL "EE/IOP Sync Hack (x3) - Makes EE and IOP hacks triple the cycle rate. ( Sometimes speeds games a bit more, but can break games. )",IDC_SYNCHACK3,
|
||||
CONTROL "EE/IOP Sync Hack (x3) - Makes EE and IOP hacks triple the cycle rate. ( Even faster, but very unstable. Use at your own risk! )",IDC_SYNCHACK3,
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,190,464,11
|
||||
CONTROL "Disable FPU Overflow Checks - *Checked = Disables overflow checks. ( Speedup! ) *Greyed = Extra overflow checks. ( Helps SPS, Slow! )",IDC_FPU_OVERFLOWHACK,
|
||||
"Button",BS_AUTO3STATE | WS_TABSTOP,15,63,483,10
|
||||
CONTROL "EE/IOP Fast Branches - Quick branching ( Very small speedup; Not Recommended! )",IDC_FASTBRANCHES,
|
||||
"Button",BS_AUTOCHECKBOX | WS_DISABLED | WS_TABSTOP,15,231,423,10
|
||||
CTEXT "If you have problems, disable all these and try again!",IDC_STATIC,7,22,497,8
|
||||
GROUPBOX "Overflow and Underflow",IDC_STATIC,7,36,497,58
|
||||
CONTROL "Disable Underflow Checks - *Checked = Disables underflow checks. ( Speedup! )",IDC_DENORMALS,
|
||||
|
@ -1071,7 +1072,7 @@ BEGIN
|
|||
CONTROL "Disable Extra FPU Flags - When checked, PCSX2 doesn't set some flags that are rarely used by games. ( Speedup! )",IDC_FPU_FLAGS,
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,126,414,10
|
||||
CONTROL "Escape Hack - Use Esc key to fully exit PCSX2.",IDC_ESCHACK,
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,259,421,10
|
||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,15,244,421,10
|
||||
PUSHBUTTON "Compatibility",IDBUTTON1,15,293,50,14
|
||||
PUSHBUTTON "Speed",IDBUTTON2,73,293,50,14
|
||||
END
|
||||
|
@ -1608,7 +1609,7 @@ BEGIN
|
|||
"Button",BS_AUTOCHECKBOX | BS_MULTILINE | WS_TABSTOP,14,143,214,18
|
||||
CONTROL "Multi threaded GS mode (MTGS)\n (faster on dual core/HT procs, requires pcsx2 restart)",IDC_CPU_GSMULTI,
|
||||
"Button",BS_AUTOCHECKBOX | BS_MULTILINE | WS_TABSTOP,7,166,231,30
|
||||
CONTROL "Dual Core Mode (DC) - Much faster but only valid with MTGS",IDC_CPU_MULTI,
|
||||
CONTROL "Dual Core Mode (DC) - Only valid with MTGS. Keeps one core busy, sometimes improving FPS. Note that this increases the heat your CPU produces, so leave it off on Notebooks.",IDC_CPU_MULTI,
|
||||
"Button",BS_AUTOCHECKBOX | BS_MULTILINE | WS_TABSTOP,7,199,232,26
|
||||
CONTROL "Normal - All frames are rendered as fast as possible.",IDC_CPU_FL_NORMAL,
|
||||
"Button",BS_AUTORADIOBUTTON | BS_MULTILINE | WS_GROUP,309,17,221,17
|
||||
|
|
|
@ -501,7 +501,6 @@
|
|||
#define IDC_SYNCHACK3 1219
|
||||
#define IDC_IOPGPR0 1220
|
||||
#define IDC_SYNCHACK4 1220
|
||||
#define IDC_FASTBRANCHES 1220
|
||||
#define IDC_IOPGPR1 1221
|
||||
#define IDC_IOPGPR2 1222
|
||||
#define IDC_IOPGPR16 1223
|
||||
|
|
|
@ -985,8 +985,6 @@ void psxSetBranchImm( u32 imm )
|
|||
*ptr = (uptr)JMP32((uptr)psxDispatcher - ( (uptr)x86Ptr + 5 ));
|
||||
}
|
||||
|
||||
#define USE_FAST_BRANCHES CHECK_FASTBRANCHES
|
||||
|
||||
//fixme : this is all a huge hack, we base the counter advancements on the average an opcode should take (wtf?)
|
||||
// If that wasn't bad enough we have default values like 9/8 which will get cast to int later
|
||||
// (yeah, that means all sync code couldn't have worked to beginn with)
|
||||
|
@ -1004,12 +1002,6 @@ static u32 psxScaleBlockCycles()
|
|||
static void iPsxBranchTest(u32 newpc, u32 cpuBranch)
|
||||
{
|
||||
u32 blockCycles = psxScaleBlockCycles();
|
||||
if( USE_FAST_BRANCHES && cpuBranch == 0 )
|
||||
{
|
||||
SUB32ItoM((uptr)&psxCycleEE, blockCycles*8 );
|
||||
ADD32ItoM((uptr)&psxRegs.cycle, blockCycles);
|
||||
return;
|
||||
}
|
||||
|
||||
MOV32MtoR(ECX, (uptr)&psxRegs.cycle);
|
||||
MOV32MtoR(EAX, (uptr)&psxCycleEE);
|
||||
|
|
|
@ -2230,8 +2230,6 @@ void iFlushCall(int flushtype)
|
|||
}
|
||||
}
|
||||
|
||||
#define USE_FAST_BRANCHES CHECK_FASTBRANCHES
|
||||
|
||||
//void testfpu()
|
||||
//{
|
||||
// int i;
|
||||
|
@ -2274,12 +2272,6 @@ static void iBranchTest(u32 newpc, u32 cpuBranch)
|
|||
//CALLFunc((uptr)testfpu);
|
||||
#endif
|
||||
|
||||
if( USE_FAST_BRANCHES && (cpuBranch==0) )
|
||||
{
|
||||
ADD32ItoM((uptr)&cpuRegs.cycle, s_nBlockCycles*EECYCLE_MULT);
|
||||
return;
|
||||
}
|
||||
|
||||
MOV32MtoR(ECX, (uptr)&cpuRegs.cycle);
|
||||
ADD32ItoR(ECX, s_nBlockCycles*EECYCLE_MULT);
|
||||
MOV32RtoM((uptr)&cpuRegs.cycle, ECX); // update cycles
|
||||
|
|
Loading…
Reference in New Issue