mirror of https://github.com/PCSX2/pcsx2.git
New Feature: Press TAB to toggle the framelimiter on/off (as a substitute for hitting F4 several times). Usable as a "turbo" feature, similar to other emus.
Many minor code cleanups to logging and constants. git-svn-id: http://pcsx2.googlecode.com/svn/trunk@595 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
070f38c136
commit
2110018e58
|
@ -400,13 +400,13 @@ static __forceinline void frameLimit()
|
||||||
|
|
||||||
static __forceinline void VSyncStart(u32 sCycle)
|
static __forceinline void VSyncStart(u32 sCycle)
|
||||||
{
|
{
|
||||||
EECNT_LOG( "///////// EE COUNTER VSYNC START \\\\\\\\\\ (frame: %d)\n", iFrame );
|
EECNT_LOG( "///////// EE COUNTER VSYNC START \\\\\\\\\\\\\\\\\\\\ (frame: %d)\n", iFrame );
|
||||||
vSyncDebugStuff(); // EE Profiling and Debug code
|
vSyncDebugStuff(); // EE Profiling and Debug code
|
||||||
|
|
||||||
if ((CSRw & 0x8)) GSCSRr|= 0x8;
|
if ((CSRw & 0x8)) GSCSRr|= 0x8;
|
||||||
if (!(GSIMR&0x800)) gsIrq();
|
if (!(GSIMR&0x800)) gsIrq();
|
||||||
|
|
||||||
hwIntcIrq(2);
|
hwIntcIrq(INTC_VBLANK_S);
|
||||||
psxVBlankStart();
|
psxVBlankStart();
|
||||||
|
|
||||||
if (gates) rcntStartGate(true, sCycle); // Counters Start Gate code
|
if (gates) rcntStartGate(true, sCycle); // Counters Start Gate code
|
||||||
|
@ -434,7 +434,7 @@ static __forceinline void VSyncStart(u32 sCycle)
|
||||||
|
|
||||||
static __forceinline void VSyncEnd(u32 sCycle)
|
static __forceinline void VSyncEnd(u32 sCycle)
|
||||||
{
|
{
|
||||||
EECNT_LOG( "///////// EE COUNTER VSYNC END \\\\\\\\\\ (frame: %d)\n", iFrame );
|
EECNT_LOG( "///////// EE COUNTER VSYNC END \\\\\\\\\\\\\\\\\\\\ (frame: %d)\n", iFrame );
|
||||||
|
|
||||||
iFrame++;
|
iFrame++;
|
||||||
|
|
||||||
|
@ -450,7 +450,7 @@ static __forceinline void VSyncEnd(u32 sCycle)
|
||||||
vu1MicroDisableSkip();
|
vu1MicroDisableSkip();
|
||||||
}
|
}
|
||||||
|
|
||||||
hwIntcIrq(3); // HW Irq
|
hwIntcIrq(INTC_VBLANK_E); // HW Irq
|
||||||
psxVBlankEnd(); // psxCounters vBlank End
|
psxVBlankEnd(); // psxCounters vBlank End
|
||||||
if (gates) rcntEndGate(true, sCycle); // Counters End Gate Code
|
if (gates) rcntEndGate(true, sCycle); // Counters End Gate Code
|
||||||
frameLimit(); // limit FPS
|
frameLimit(); // limit FPS
|
||||||
|
|
|
@ -199,7 +199,7 @@ void __fastcall WriteFIFO_page_7(u32 mem, const mem128_t *value)
|
||||||
// All addresses in this page map to 0x7000 and 0x7010:
|
// All addresses in this page map to 0x7000 and 0x7010:
|
||||||
mem &= 0x10;
|
mem &= 0x10;
|
||||||
|
|
||||||
IPU_LOG( "WriteFIFO/IPU, addr=0x%x", params mem );
|
IPU_LOG( "WriteFIFO/IPU, addr=0x%x\n", params mem );
|
||||||
|
|
||||||
if( mem == 0 )
|
if( mem == 0 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -507,7 +507,7 @@ void __fastcall gsWrite128_generic( u32 mem, const mem128_t* value )
|
||||||
{
|
{
|
||||||
const u32* const srcval32 = (u32*)value;
|
const u32* const srcval32 = (u32*)value;
|
||||||
|
|
||||||
GIF_LOG("GS Write64 at %8.8lx with data %8.8x_%8.8x_%8.8x_%8.8x \n", mem,
|
GIF_LOG("GS Write128 at %8.8lx with data %8.8x_%8.8x_%8.8x_%8.8x \n", mem,
|
||||||
srcval32[3], srcval32[2], srcval32[1], srcval32[0]);
|
srcval32[3], srcval32[2], srcval32[1], srcval32[0]);
|
||||||
|
|
||||||
const uint masked_mem = mem & 0x13ff;
|
const uint masked_mem = mem & 0x13ff;
|
||||||
|
@ -582,7 +582,7 @@ __forceinline u64 gsRead64(u32 mem)
|
||||||
}
|
}
|
||||||
|
|
||||||
void gsIrq() {
|
void gsIrq() {
|
||||||
hwIntcIrq(0);
|
hwIntcIrq(INTC_GS);
|
||||||
}
|
}
|
||||||
|
|
||||||
void gsSyncLimiterLostTime( s32 deltaTime )
|
void gsSyncLimiterLostTime( s32 deltaTime )
|
||||||
|
|
|
@ -218,7 +218,7 @@ static __forceinline mem32_t __hwRead32_page_0F( u32 mem, bool intchack )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0xf010:
|
case 0xf010:
|
||||||
HW_LOG("INTC_MASK Read32, value=0x%x", psHu32(INTC_MASK));
|
HW_LOG("INTC_MASK Read32, value=0x%x\n", psHu32(INTC_MASK));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0xf130: // 0x1000f130
|
case 0xf130: // 0x1000f130
|
||||||
|
|
|
@ -269,13 +269,12 @@ __forceinline u64 ipuRead64(u32 mem)
|
||||||
|
|
||||||
#ifdef PCSX2_DEVBUILD
|
#ifdef PCSX2_DEVBUILD
|
||||||
if( mem == 0x10002010 ) {
|
if( mem == 0x10002010 ) {
|
||||||
SysPrintf("reading 64bit IPU ctrl\n");
|
Console::Notice("reading 64bit IPU ctrl");
|
||||||
}
|
}
|
||||||
if( mem == 0x10002020 ) {
|
if( mem == 0x10002020 ) {
|
||||||
SysPrintf("reading 64bit IPU top\n");
|
Console::Notice("reading 64bit IPU top");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
switch (mem){
|
switch (mem){
|
||||||
case 0x10002000: // IPU_CMD
|
case 0x10002000: // IPU_CMD
|
||||||
|
|
||||||
|
|
|
@ -728,6 +728,10 @@ void KeyEvent(keyEvent* ev)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case XK_Tab:
|
||||||
|
CycleFrameLimit(0);
|
||||||
|
break;
|
||||||
|
|
||||||
case XK_Escape:
|
case XK_Escape:
|
||||||
signal(SIGINT, SIG_DFL);
|
signal(SIGINT, SIG_DFL);
|
||||||
signal(SIGPIPE, SIG_DFL);
|
signal(SIGPIPE, SIG_DFL);
|
||||||
|
|
110
pcsx2/Misc.cpp
110
pcsx2/Misc.cpp
|
@ -516,6 +516,66 @@ static void GetGSStateFilename( string& dest )
|
||||||
Path::Combine( dest, SSTATES_DIR, gsText );
|
Path::Combine( dest, SSTATES_DIR, gsText );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CycleFrameLimit(int dir)
|
||||||
|
{
|
||||||
|
const char* limitMsg;
|
||||||
|
u32 newOptions;
|
||||||
|
u32 curFrameLimit = Config.Options & PCSX2_FRAMELIMIT_MASK;
|
||||||
|
u32 newFrameLimit;
|
||||||
|
static u32 oldFrameLimit = PCSX2_FRAMELIMIT_LIMIT;
|
||||||
|
|
||||||
|
if( dir == 0 ) {
|
||||||
|
// turn off limit or restore previous limit mode
|
||||||
|
if (curFrameLimit) {
|
||||||
|
oldFrameLimit = curFrameLimit;
|
||||||
|
newFrameLimit = 0;
|
||||||
|
} else
|
||||||
|
newFrameLimit = oldFrameLimit;
|
||||||
|
} else if (dir > 0) {
|
||||||
|
// next
|
||||||
|
newFrameLimit = (curFrameLimit + PCSX2_FRAMELIMIT_LIMIT) & PCSX2_FRAMELIMIT_MASK;
|
||||||
|
} else {
|
||||||
|
// previous
|
||||||
|
newFrameLimit = (curFrameLimit + PCSX2_FRAMELIMIT_VUSKIP) & PCSX2_FRAMELIMIT_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
newOptions = (Config.Options & ~PCSX2_FRAMELIMIT_MASK) | newFrameLimit;
|
||||||
|
|
||||||
|
gsResetFrameSkip();
|
||||||
|
|
||||||
|
switch(newFrameLimit) {
|
||||||
|
case PCSX2_FRAMELIMIT_NORMAL:
|
||||||
|
limitMsg = "None/Normal";
|
||||||
|
break;
|
||||||
|
case PCSX2_FRAMELIMIT_LIMIT:
|
||||||
|
limitMsg = "Limit";
|
||||||
|
break;
|
||||||
|
case PCSX2_FRAMELIMIT_SKIP:
|
||||||
|
case PCSX2_FRAMELIMIT_VUSKIP:
|
||||||
|
if( GSsetFrameSkip == NULL )
|
||||||
|
{
|
||||||
|
newOptions &= ~PCSX2_FRAMELIMIT_MASK;
|
||||||
|
Console::Notice("Notice: GS Plugin does not support frameskipping.");
|
||||||
|
limitMsg = "None/Normal";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// When enabling Skipping we have to make sure Skipper (GS) and Limiter (EE)
|
||||||
|
// are properly synchronized.
|
||||||
|
gsDynamicSkipEnable();
|
||||||
|
limitMsg = ((newOptions & PCSX2_FRAMELIMIT_MASK) == PCSX2_FRAMELIMIT_SKIP) ? "Skip" : "VUSkip";
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
Threading::AtomicExchange( Config.Options, newOptions );
|
||||||
|
|
||||||
|
Console::Notice("Frame Limit Mode Changed: %s", params limitMsg );
|
||||||
|
|
||||||
|
// [Air]: Do we really want to save runtime changes to frameskipping?
|
||||||
|
//SaveConfig();
|
||||||
|
}
|
||||||
|
|
||||||
void ProcessFKeys(int fkey, int shift)
|
void ProcessFKeys(int fkey, int shift)
|
||||||
{
|
{
|
||||||
string Text;
|
string Text;
|
||||||
|
@ -590,54 +650,8 @@ void ProcessFKeys(int fkey, int shift)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
{
|
CycleFrameLimit(shift ? -1 : 1);
|
||||||
const char* limitMsg;
|
break;
|
||||||
u32 newOptions;
|
|
||||||
// cycle
|
|
||||||
if( shift ) {
|
|
||||||
// previous
|
|
||||||
newOptions = (Config.Options&~PCSX2_FRAMELIMIT_MASK)|(((Config.Options&PCSX2_FRAMELIMIT_MASK)+PCSX2_FRAMELIMIT_VUSKIP)&PCSX2_FRAMELIMIT_MASK);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// next
|
|
||||||
newOptions = (Config.Options&~PCSX2_FRAMELIMIT_MASK)|(((Config.Options&PCSX2_FRAMELIMIT_MASK)+PCSX2_FRAMELIMIT_LIMIT)&PCSX2_FRAMELIMIT_MASK);
|
|
||||||
}
|
|
||||||
|
|
||||||
gsResetFrameSkip();
|
|
||||||
|
|
||||||
switch(newOptions & PCSX2_FRAMELIMIT_MASK) {
|
|
||||||
case PCSX2_FRAMELIMIT_NORMAL:
|
|
||||||
limitMsg = "None/Normal";
|
|
||||||
break;
|
|
||||||
case PCSX2_FRAMELIMIT_LIMIT:
|
|
||||||
limitMsg = "Limit";
|
|
||||||
break;
|
|
||||||
case PCSX2_FRAMELIMIT_SKIP:
|
|
||||||
case PCSX2_FRAMELIMIT_VUSKIP:
|
|
||||||
if( GSsetFrameSkip == NULL )
|
|
||||||
{
|
|
||||||
newOptions &= ~PCSX2_FRAMELIMIT_MASK;
|
|
||||||
Console::Notice("Notice: GS Plugin does not support frameskipping.");
|
|
||||||
limitMsg = "None/Normal";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// When enabling Skipping we have to make sure Skipper (GS) and Limiter (EE)
|
|
||||||
// are properly synchronized.
|
|
||||||
gsDynamicSkipEnable();
|
|
||||||
limitMsg = ((newOptions & PCSX2_FRAMELIMIT_MASK) == PCSX2_FRAMELIMIT_SKIP) ? "Skip" : "VUSkip";
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
Threading::AtomicExchange( Config.Options, newOptions );
|
|
||||||
|
|
||||||
Console::Notice("Frame Limit Mode Changed: %s", params limitMsg );
|
|
||||||
|
|
||||||
// [Air]: Do we really want to save runtime changes to frameskipping?
|
|
||||||
//SaveConfig();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// note: VK_F5-VK_F7 are reserved for GS
|
// note: VK_F5-VK_F7 are reserved for GS
|
||||||
case 8:
|
case 8:
|
||||||
|
|
|
@ -184,6 +184,7 @@ void SaveGSState(const string& file);
|
||||||
void LoadGSState(const string& file);
|
void LoadGSState(const string& file);
|
||||||
|
|
||||||
char *ParseLang(char *id);
|
char *ParseLang(char *id);
|
||||||
|
void CycleFrameLimit(int dir);
|
||||||
void ProcessFKeys(int fkey, int shift); // processes fkey related commands value 1-12
|
void ProcessFKeys(int fkey, int shift); // processes fkey related commands value 1-12
|
||||||
|
|
||||||
#define DIRENTRY_SIZE 16
|
#define DIRENTRY_SIZE 16
|
||||||
|
|
|
@ -592,7 +592,7 @@ void vifMFIFOInterrupt()
|
||||||
{
|
{
|
||||||
if(vif1.irq && vif1.tag.size == 0) {
|
if(vif1.irq && vif1.tag.size == 0) {
|
||||||
vif1Regs->stat|= VIF1_STAT_INT;
|
vif1Regs->stat|= VIF1_STAT_INT;
|
||||||
hwIntcIrq(5);
|
hwIntcIrq(INTC_VIF1);
|
||||||
--vif1.irq;
|
--vif1.irq;
|
||||||
if(vif1Regs->stat & (VIF1_STAT_VSS|VIF1_STAT_VIS|VIF1_STAT_VFS))
|
if(vif1Regs->stat & (VIF1_STAT_VSS|VIF1_STAT_VIS|VIF1_STAT_VFS))
|
||||||
{
|
{
|
||||||
|
|
|
@ -257,7 +257,7 @@ void __fastcall memRead32(u32 mem, u32 *out) { *out = vtlb_memRead32( mem ); }
|
||||||
// Error / TLB Miss Handlers
|
// Error / TLB Miss Handlers
|
||||||
//
|
//
|
||||||
|
|
||||||
// Generates a VtlbMiss Exception
|
// Generates a tlbMiss Exception
|
||||||
static __forceinline void vtlb_Miss(u32 addr,u32 mode)
|
static __forceinline void vtlb_Miss(u32 addr,u32 mode)
|
||||||
{
|
{
|
||||||
Console::Error("vtlb miss : addr 0x%X, mode %d", params addr,mode);
|
Console::Error("vtlb miss : addr 0x%X, mode %d", params addr,mode);
|
||||||
|
@ -270,7 +270,7 @@ static __forceinline void vtlb_Miss(u32 addr,u32 mode)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Just dies a horrible death for now.
|
// Just dies a horrible death for now.
|
||||||
//
|
// Eventually should generate a BusError exception.
|
||||||
static __forceinline void vtlb_BusError(u32 addr,u32 mode)
|
static __forceinline void vtlb_BusError(u32 addr,u32 mode)
|
||||||
{
|
{
|
||||||
Console::Error("vtlb bus error : addr 0x%X, mode %d\n",params addr,mode);
|
Console::Error("vtlb bus error : addr 0x%X, mode %d\n",params addr,mode);
|
||||||
|
|
|
@ -668,6 +668,10 @@ static void __fastcall KeyEvent(keyEvent* ev)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VK_TAB:
|
||||||
|
CycleFrameLimit(0);
|
||||||
|
break;
|
||||||
|
|
||||||
case VK_ESCAPE:
|
case VK_ESCAPE:
|
||||||
#ifdef PCSX2_DEVBUILD
|
#ifdef PCSX2_DEVBUILD
|
||||||
if( g_SaveGSStream >= 3 ) {
|
if( g_SaveGSStream >= 3 ) {
|
||||||
|
|
|
@ -227,16 +227,13 @@ int hwConstRead32(u32 x86reg, u32 mem)
|
||||||
iFlushCall(0);
|
iFlushCall(0);
|
||||||
PUSH32I(0);
|
PUSH32I(0);
|
||||||
CALLFunc((uptr)rcntRcount);
|
CALLFunc((uptr)rcntRcount);
|
||||||
EECNT_LOG("Counter 0 count read = %x\n", rcntRcount(0));
|
|
||||||
ADD32ItoR(ESP, 4);
|
ADD32ItoR(ESP, 4);
|
||||||
return 1;
|
return 1;
|
||||||
case 0x10000010:
|
case 0x10000010:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[0].mode);
|
_eeReadConstMem32(x86reg, (uptr)&counters[0].mode);
|
||||||
EECNT_LOG("Counter 0 mode read = %x\n", counters[0].modeval);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10000020:
|
case 0x10000020:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[0].target);
|
_eeReadConstMem32(x86reg, (uptr)&counters[0].target);
|
||||||
EECNT_LOG("Counter 0 target read = %x\n", counters[0].target);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10000030:
|
case 0x10000030:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[0].hold);
|
_eeReadConstMem32(x86reg, (uptr)&counters[0].hold);
|
||||||
|
@ -246,16 +243,13 @@ int hwConstRead32(u32 x86reg, u32 mem)
|
||||||
iFlushCall(0);
|
iFlushCall(0);
|
||||||
PUSH32I(1);
|
PUSH32I(1);
|
||||||
CALLFunc((uptr)rcntRcount);
|
CALLFunc((uptr)rcntRcount);
|
||||||
EECNT_LOG("Counter 1 count read = %x\n", rcntRcount(1));
|
|
||||||
ADD32ItoR(ESP, 4);
|
ADD32ItoR(ESP, 4);
|
||||||
return 1;
|
return 1;
|
||||||
case 0x10000810:
|
case 0x10000810:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[1].mode);
|
_eeReadConstMem32(x86reg, (uptr)&counters[1].mode);
|
||||||
EECNT_LOG("Counter 1 mode read = %x\n", counters[1].modeval);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10000820:
|
case 0x10000820:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[1].target);
|
_eeReadConstMem32(x86reg, (uptr)&counters[1].target);
|
||||||
EECNT_LOG("Counter 1 target read = %x\n", counters[1].target);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10000830:
|
case 0x10000830:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[1].hold);
|
_eeReadConstMem32(x86reg, (uptr)&counters[1].hold);
|
||||||
|
@ -265,16 +259,13 @@ int hwConstRead32(u32 x86reg, u32 mem)
|
||||||
iFlushCall(0);
|
iFlushCall(0);
|
||||||
PUSH32I(2);
|
PUSH32I(2);
|
||||||
CALLFunc((uptr)rcntRcount);
|
CALLFunc((uptr)rcntRcount);
|
||||||
EECNT_LOG("Counter 2 count read = %x\n", rcntRcount(2));
|
|
||||||
ADD32ItoR(ESP, 4);
|
ADD32ItoR(ESP, 4);
|
||||||
return 1;
|
return 1;
|
||||||
case 0x10001010:
|
case 0x10001010:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[2].mode);
|
_eeReadConstMem32(x86reg, (uptr)&counters[2].mode);
|
||||||
EECNT_LOG("Counter 2 mode read = %x\n", counters[2].modeval);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10001020:
|
case 0x10001020:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[2].target);
|
_eeReadConstMem32(x86reg, (uptr)&counters[2].target);
|
||||||
EECNT_LOG("Counter 2 target read = %x\n", counters[2].target);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10001030:
|
case 0x10001030:
|
||||||
// fixme: Counters[2].hold and Counters[3].hold are never assigned values
|
// fixme: Counters[2].hold and Counters[3].hold are never assigned values
|
||||||
|
@ -286,16 +277,13 @@ int hwConstRead32(u32 x86reg, u32 mem)
|
||||||
iFlushCall(0);
|
iFlushCall(0);
|
||||||
PUSH32I(3);
|
PUSH32I(3);
|
||||||
CALLFunc((uptr)rcntRcount);
|
CALLFunc((uptr)rcntRcount);
|
||||||
EECNT_LOG("Counter 3 count read = %x\n", rcntRcount(3));
|
|
||||||
ADD32ItoR(ESP, 4);
|
ADD32ItoR(ESP, 4);
|
||||||
return 1;
|
return 1;
|
||||||
case 0x10001810:
|
case 0x10001810:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[3].mode);
|
_eeReadConstMem32(x86reg, (uptr)&counters[3].mode);
|
||||||
EECNT_LOG("Counter 3 mode read = %x\n", counters[3].modeval);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10001820:
|
case 0x10001820:
|
||||||
_eeReadConstMem32(x86reg, (uptr)&counters[3].target);
|
_eeReadConstMem32(x86reg, (uptr)&counters[3].target);
|
||||||
EECNT_LOG("Counter 3 target read = %x\n", counters[3].target);
|
|
||||||
return 0;
|
return 0;
|
||||||
case 0x10001830:
|
case 0x10001830:
|
||||||
// fixme: Counters[2].hold and Counters[3].hold are never assigned values
|
// fixme: Counters[2].hold and Counters[3].hold are never assigned values
|
||||||
|
|
Loading…
Reference in New Issue