mirror of https://github.com/PCSX2/pcsx2.git
Counters: Retool UpdateVSyncRate
This commit is contained in:
parent
d7e54ccbed
commit
77f8a0f5f6
|
@ -511,7 +511,7 @@ void EmuThread::setFullscreen(bool fullscreen)
|
||||||
GetMTGS().WaitGS();
|
GetMTGS().WaitGS();
|
||||||
|
|
||||||
// If we're using exclusive fullscreen, the refresh rate may have changed.
|
// If we're using exclusive fullscreen, the refresh rate may have changed.
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmuThread::setSurfaceless(bool surfaceless)
|
void EmuThread::setSurfaceless(bool surfaceless)
|
||||||
|
|
|
@ -226,10 +226,11 @@ static void vSyncInfoCalc(vSyncTimingInfo* info, double framesPerSecond, u32 sca
|
||||||
// Dynasty Warriors 3 Xtreme Legends - fake save corruption when loading save
|
// Dynasty Warriors 3 Xtreme Legends - fake save corruption when loading save
|
||||||
// Jak II - random speedups
|
// Jak II - random speedups
|
||||||
// Shadow of Rome - FMV audio issues
|
// Shadow of Rome - FMV audio issues
|
||||||
|
const bool ntsc_hblank = gsVideoMode != GS_VideoMode::PAL && gsVideoMode == GS_VideoMode::DVD_PAL;
|
||||||
const u64 HalfFrame = Frame / 2;
|
const u64 HalfFrame = Frame / 2;
|
||||||
const u64 Blank = Scanline * ((gsVideoMode == GS_VideoMode::NTSC ? 22 : 25) + static_cast<int>(gsIsInterlaced));
|
const u64 Blank = Scanline * ((ntsc_hblank ? 22 : 25) + static_cast<int>(!IsProgressiveVideoMode()));
|
||||||
const u64 Render = HalfFrame - Blank;
|
const u64 Render = HalfFrame - Blank;
|
||||||
const u64 GSBlank = Scanline * (gsVideoMode == GS_VideoMode::NTSC ? 3.5 : 3); // GS VBlank/CSR Swap happens roughly 3.5(NTSC) and 3(PAL) Scanlines after VBlank Start
|
const u64 GSBlank = Scanline * (ntsc_hblank ? 3.5 : 3); // GS VBlank/CSR Swap happens roughly 3.5(NTSC) and 3(PAL) Scanlines after VBlank Start
|
||||||
|
|
||||||
// Important! The hRender/hBlank timers should be 50/50 for best results.
|
// Important! The hRender/hBlank timers should be 50/50 for best results.
|
||||||
// (this appears to be what the real EE's timing crystal does anyway)
|
// (this appears to be what the real EE's timing crystal does anyway)
|
||||||
|
@ -321,6 +322,7 @@ double GetVerticalFrequency()
|
||||||
// https://web.archive.org/web/20201102100937/http://forums.nesdev.com/viewtopic.php?t=7909
|
// https://web.archive.org/web/20201102100937/http://forums.nesdev.com/viewtopic.php?t=7909
|
||||||
// https://web.archive.org/web/20120629231826fw_/http://ntsc-tv.com/index.html
|
// https://web.archive.org/web/20120629231826fw_/http://ntsc-tv.com/index.html
|
||||||
// https://web.archive.org/web/20200831051302/https://www.hdretrovision.com/240p/
|
// https://web.archive.org/web/20200831051302/https://www.hdretrovision.com/240p/
|
||||||
|
|
||||||
switch (gsVideoMode)
|
switch (gsVideoMode)
|
||||||
{
|
{
|
||||||
case GS_VideoMode::Uninitialized: // SetGsCrt hasn't executed yet, give some temporary values.
|
case GS_VideoMode::Uninitialized: // SetGsCrt hasn't executed yet, give some temporary values.
|
||||||
|
@ -378,7 +380,7 @@ static double AdjustToHostRefreshRate(double vertical_frequency, double frame_li
|
||||||
return frame_limit;
|
return frame_limit;
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 UpdateVSyncRate()
|
void UpdateVSyncRate(bool force)
|
||||||
{
|
{
|
||||||
// Notice: (and I probably repeat this elsewhere, but it's worth repeating)
|
// Notice: (and I probably repeat this elsewhere, but it's worth repeating)
|
||||||
// The PS2's vsync timer is an *independent* crystal that is fixed to either 59.94 (NTSC)
|
// The PS2's vsync timer is an *independent* crystal that is fixed to either 59.94 (NTSC)
|
||||||
|
@ -389,62 +391,63 @@ u32 UpdateVSyncRate()
|
||||||
const double vertical_frequency = GetVerticalFrequency();
|
const double vertical_frequency = GetVerticalFrequency();
|
||||||
|
|
||||||
const double frames_per_second = vertical_frequency / 2.0;
|
const double frames_per_second = vertical_frequency / 2.0;
|
||||||
const double frame_limit = AdjustToHostRefreshRate(vertical_frequency, frames_per_second * EmuConfig.GS.LimitScalar);
|
|
||||||
|
|
||||||
const double tick_rate = GetTickFrequency() / 2.0;
|
if (vSyncInfo.Framerate != frames_per_second || vSyncInfo.VideoMode != gsVideoMode || force)
|
||||||
const s64 ticks = static_cast<s64>(tick_rate / std::max(frame_limit, 1.0));
|
|
||||||
|
|
||||||
u32 total_scanlines = 0;
|
|
||||||
bool custom = false;
|
|
||||||
|
|
||||||
switch (gsVideoMode)
|
|
||||||
{
|
{
|
||||||
case GS_VideoMode::Uninitialized: // SYSCALL instruction hasn't executed yet, give some temporary values.
|
const double frame_limit = AdjustToHostRefreshRate(vertical_frequency, frames_per_second * EmuConfig.GS.LimitScalar);
|
||||||
if(gsIsInterlaced)
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
|
||||||
else
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_NI;
|
|
||||||
break;
|
|
||||||
case GS_VideoMode::PAL:
|
|
||||||
case GS_VideoMode::DVD_PAL:
|
|
||||||
custom = (EmuConfig.GS.FrameratePAL != Pcsx2Config::GSOptions::DEFAULT_FRAME_RATE_PAL);
|
|
||||||
if (gsIsInterlaced)
|
|
||||||
total_scanlines = SCANLINES_TOTAL_PAL_I;
|
|
||||||
else
|
|
||||||
total_scanlines = SCANLINES_TOTAL_PAL_NI;
|
|
||||||
break;
|
|
||||||
case GS_VideoMode::NTSC:
|
|
||||||
case GS_VideoMode::DVD_NTSC:
|
|
||||||
custom = (EmuConfig.GS.FramerateNTSC != Pcsx2Config::GSOptions::DEFAULT_FRAME_RATE_NTSC);
|
|
||||||
if (gsIsInterlaced)
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
|
||||||
else
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_NI;
|
|
||||||
break;
|
|
||||||
case GS_VideoMode::SDTV_480P:
|
|
||||||
case GS_VideoMode::SDTV_576P:
|
|
||||||
case GS_VideoMode::HDTV_720P:
|
|
||||||
case GS_VideoMode::VESA:
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
|
||||||
break;
|
|
||||||
case GS_VideoMode::HDTV_1080P:
|
|
||||||
case GS_VideoMode::HDTV_1080I:
|
|
||||||
total_scanlines = SCANLINES_TOTAL_1080;
|
|
||||||
break;
|
|
||||||
case GS_VideoMode::Unknown:
|
|
||||||
default:
|
|
||||||
if (gsIsInterlaced)
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
|
||||||
else
|
|
||||||
total_scanlines = SCANLINES_TOTAL_NTSC_NI;
|
|
||||||
Console.Error("PCSX2-Counters: Unknown video mode detected");
|
|
||||||
pxAssertDev(false , "Unknown video mode detected via SetGsCrt");
|
|
||||||
}
|
|
||||||
|
|
||||||
const bool video_mode_initialized = gsVideoMode != GS_VideoMode::Uninitialized;
|
const double tick_rate = GetTickFrequency() / 2.0;
|
||||||
|
const s64 ticks = static_cast<s64>(tick_rate / std::max(frame_limit, 1.0));
|
||||||
|
|
||||||
|
u32 total_scanlines = 0;
|
||||||
|
bool custom = false;
|
||||||
|
|
||||||
|
switch (gsVideoMode)
|
||||||
|
{
|
||||||
|
case GS_VideoMode::Uninitialized: // SYSCALL instruction hasn't executed yet, give some temporary values.
|
||||||
|
if (gsIsInterlaced)
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
||||||
|
else
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_NI;
|
||||||
|
break;
|
||||||
|
case GS_VideoMode::PAL:
|
||||||
|
case GS_VideoMode::DVD_PAL:
|
||||||
|
custom = (EmuConfig.GS.FrameratePAL != Pcsx2Config::GSOptions::DEFAULT_FRAME_RATE_PAL);
|
||||||
|
if (gsIsInterlaced)
|
||||||
|
total_scanlines = SCANLINES_TOTAL_PAL_I;
|
||||||
|
else
|
||||||
|
total_scanlines = SCANLINES_TOTAL_PAL_NI;
|
||||||
|
break;
|
||||||
|
case GS_VideoMode::NTSC:
|
||||||
|
case GS_VideoMode::DVD_NTSC:
|
||||||
|
custom = (EmuConfig.GS.FramerateNTSC != Pcsx2Config::GSOptions::DEFAULT_FRAME_RATE_NTSC);
|
||||||
|
if (gsIsInterlaced)
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
||||||
|
else
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_NI;
|
||||||
|
break;
|
||||||
|
case GS_VideoMode::SDTV_480P:
|
||||||
|
case GS_VideoMode::SDTV_576P:
|
||||||
|
case GS_VideoMode::HDTV_720P:
|
||||||
|
case GS_VideoMode::VESA:
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
||||||
|
break;
|
||||||
|
case GS_VideoMode::HDTV_1080P:
|
||||||
|
case GS_VideoMode::HDTV_1080I:
|
||||||
|
total_scanlines = SCANLINES_TOTAL_1080;
|
||||||
|
break;
|
||||||
|
case GS_VideoMode::Unknown:
|
||||||
|
default:
|
||||||
|
if (gsIsInterlaced)
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_I;
|
||||||
|
else
|
||||||
|
total_scanlines = SCANLINES_TOTAL_NTSC_NI;
|
||||||
|
Console.Error("PCSX2-Counters: Unknown video mode detected");
|
||||||
|
pxAssertDev(false, "Unknown video mode detected via SetGsCrt");
|
||||||
|
}
|
||||||
|
|
||||||
|
const bool video_mode_initialized = gsVideoMode != GS_VideoMode::Uninitialized;
|
||||||
|
|
||||||
if (vSyncInfo.Framerate != frames_per_second || vSyncInfo.VideoMode != gsVideoMode)
|
|
||||||
{
|
|
||||||
// NBA Jam 2004 PAL will fail to display 3D on the menu if this value isn't correct on reset.
|
// NBA Jam 2004 PAL will fail to display 3D on the menu if this value isn't correct on reset.
|
||||||
if (video_mode_initialized && vSyncInfo.VideoMode != gsVideoMode)
|
if (video_mode_initialized && vSyncInfo.VideoMode != gsVideoMode)
|
||||||
CSRreg.FIELD = 1;
|
CSRreg.FIELD = 1;
|
||||||
|
@ -465,16 +468,14 @@ u32 UpdateVSyncRate()
|
||||||
vsyncCounter.sCycle = cpuRegs.cycle;
|
vsyncCounter.sCycle = cpuRegs.cycle;
|
||||||
vsyncCounter.Mode = MODE_VRENDER;
|
vsyncCounter.Mode = MODE_VRENDER;
|
||||||
cpuRcntSet();
|
cpuRcntSet();
|
||||||
|
|
||||||
|
PerformanceMetrics::SetVerticalFrequency(vertical_frequency);
|
||||||
|
|
||||||
|
if (m_iTicks != ticks)
|
||||||
|
m_iTicks = ticks;
|
||||||
|
|
||||||
|
m_iStart = GetCPUTicks();
|
||||||
}
|
}
|
||||||
|
|
||||||
PerformanceMetrics::SetVerticalFrequency(vertical_frequency);
|
|
||||||
|
|
||||||
if (m_iTicks != ticks)
|
|
||||||
m_iTicks = ticks;
|
|
||||||
|
|
||||||
m_iStart = GetCPUTicks();
|
|
||||||
|
|
||||||
return static_cast<u32>(m_iTicks);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void frameLimitReset()
|
void frameLimitReset()
|
||||||
|
|
|
@ -145,6 +145,6 @@ extern u32 rcntRcount(int index);
|
||||||
template< uint page > extern bool rcntWrite32( u32 mem, mem32_t& value );
|
template< uint page > extern bool rcntWrite32( u32 mem, mem32_t& value );
|
||||||
template< uint page > extern u16 rcntRead32( u32 mem ); // returns u16 by design! (see implementation for details)
|
template< uint page > extern u16 rcntRead32( u32 mem ); // returns u16 by design! (see implementation for details)
|
||||||
|
|
||||||
extern u32 UpdateVSyncRate();
|
extern void UpdateVSyncRate(bool force);
|
||||||
extern void frameLimitReset();
|
extern void frameLimitReset();
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ static bool s_GSRegistersWritten = false;
|
||||||
void gsSetVideoMode(GS_VideoMode mode)
|
void gsSetVideoMode(GS_VideoMode mode)
|
||||||
{
|
{
|
||||||
gsVideoMode = mode;
|
gsVideoMode = mode;
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure framelimiter options are in sync with GS capabilities.
|
// Make sure framelimiter options are in sync with GS capabilities.
|
||||||
|
@ -40,7 +40,7 @@ void gsReset()
|
||||||
GetMTGS().ResetGS(true);
|
GetMTGS().ResetGS(true);
|
||||||
gsVideoMode = GS_VideoMode::Uninitialized;
|
gsVideoMode = GS_VideoMode::Uninitialized;
|
||||||
memzero(g_RealGSMem);
|
memzero(g_RealGSMem);
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void gsUpdateFrequency(Pcsx2Config& config)
|
void gsUpdateFrequency(Pcsx2Config& config)
|
||||||
|
@ -71,7 +71,7 @@ void gsUpdateFrequency(Pcsx2Config& config)
|
||||||
}
|
}
|
||||||
|
|
||||||
GetMTGS().UpdateVSyncMode();
|
GetMTGS().UpdateVSyncMode();
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
static __fi void gsCSRwrite( const tGS_CSR& csr )
|
static __fi void gsCSRwrite( const tGS_CSR& csr )
|
||||||
|
@ -227,7 +227,7 @@ void gsWrite64_page_00( u32 mem, u64 value )
|
||||||
if (mem == GS_SMODE1 || mem == GS_SMODE2)
|
if (mem == GS_SMODE1 || mem == GS_SMODE2)
|
||||||
{
|
{
|
||||||
if (value != *(u64*)PS2GS_BASE(mem))
|
if (value != *(u64*)PS2GS_BASE(mem))
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
gsWrite64_generic( mem, value );
|
gsWrite64_generic( mem, value );
|
||||||
|
|
|
@ -91,7 +91,7 @@ static void PostLoadPrep()
|
||||||
CBreakPoints::SetSkipFirst(BREAKPOINT_EE, 0);
|
CBreakPoints::SetSkipFirst(BREAKPOINT_EE, 0);
|
||||||
CBreakPoints::SetSkipFirst(BREAKPOINT_IOP, 0);
|
CBreakPoints::SetSkipFirst(BREAKPOINT_IOP, 0);
|
||||||
|
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
|
|
@ -1196,7 +1196,7 @@ void VMManager::Reset()
|
||||||
|
|
||||||
SysClearExecutionCache();
|
SysClearExecutionCache();
|
||||||
memBindConditionalHandlers();
|
memBindConditionalHandlers();
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
frameLimitReset();
|
frameLimitReset();
|
||||||
cpuReset();
|
cpuReset();
|
||||||
|
|
||||||
|
@ -1701,7 +1701,7 @@ void VMManager::CheckForGSConfigChanges(const Pcsx2Config& old_config)
|
||||||
EmuConfig.LimiterMode = GetInitialLimiterMode();
|
EmuConfig.LimiterMode = GetInitialLimiterMode();
|
||||||
|
|
||||||
gsUpdateFrequency(EmuConfig);
|
gsUpdateFrequency(EmuConfig);
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
frameLimitReset();
|
frameLimitReset();
|
||||||
GetMTGS().ApplySettings();
|
GetMTGS().ApplySettings();
|
||||||
}
|
}
|
||||||
|
@ -1713,7 +1713,7 @@ void VMManager::CheckForFramerateConfigChanges(const Pcsx2Config& old_config)
|
||||||
|
|
||||||
Console.WriteLn("Updating frame rate configuration");
|
Console.WriteLn("Updating frame rate configuration");
|
||||||
gsUpdateFrequency(EmuConfig);
|
gsUpdateFrequency(EmuConfig);
|
||||||
UpdateVSyncRate();
|
UpdateVSyncRate(true);
|
||||||
frameLimitReset();
|
frameLimitReset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue