ThrottleCallback: use microseconds to represent realtime

Using milliseconds doesn't provide a lot of granularity, and we can use
all we can get for performance analysis.
This commit is contained in:
Pierre Bourdon 2018-08-27 01:35:16 +02:00
parent dc5a678fca
commit eadb4a66a5

View File

@ -200,9 +200,9 @@ static void ThrottleCallback(u64 last_time, s64 cyclesLate)
// Allow the GPU thread to sleep. Setting this flag here limits the wakeups to 1 kHz. // Allow the GPU thread to sleep. Setting this flag here limits the wakeups to 1 kHz.
Fifo::GpuMaySleep(); Fifo::GpuMaySleep();
u32 time = Common::Timer::GetTimeMs(); u64 time = Common::Timer::GetTimeUs();
int diff = (u32)last_time - time; s64 diff = last_time - time;
const SConfig& config = SConfig::GetInstance(); const SConfig& config = SConfig::GetInstance();
bool frame_limiter = config.m_EmulationSpeed > 0.0f && !Core::GetIsThrottlerTempDisabled(); bool frame_limiter = config.m_EmulationSpeed > 0.0f && !Core::GetIsThrottlerTempDisabled();
u32 next_event = GetTicksPerSecond() / 1000; u32 next_event = GetTicksPerSecond() / 1000;
@ -210,17 +210,17 @@ static void ThrottleCallback(u64 last_time, s64 cyclesLate)
{ {
if (config.m_EmulationSpeed != 1.0f) if (config.m_EmulationSpeed != 1.0f)
next_event = u32(next_event * config.m_EmulationSpeed); next_event = u32(next_event * config.m_EmulationSpeed);
const int max_fallback = config.iTimingVariance; const s64 max_fallback = config.iTimingVariance * 1000;
if (abs(diff) > max_fallback) if (abs(diff) > max_fallback)
{ {
DEBUG_LOG(COMMON, "system too %s, %d ms skipped", diff < 0 ? "slow" : "fast", DEBUG_LOG(COMMON, "system too %s, %d ms skipped", diff < 0 ? "slow" : "fast",
abs(diff) - max_fallback); abs(diff) - max_fallback);
last_time = time - max_fallback; last_time = time - max_fallback;
} }
else if (diff > 0) else if ((diff / 1000) > 0)
Common::SleepCurrentThread(diff); Common::SleepCurrentThread(diff / 1000);
} }
CoreTiming::ScheduleEvent(next_event - cyclesLate, et_Throttle, last_time + 1); CoreTiming::ScheduleEvent(next_event - cyclesLate, et_Throttle, last_time + 1000);
} }
// split from Init to break a circular dependency between VideoInterface::Init and // split from Init to break a circular dependency between VideoInterface::Init and
@ -282,7 +282,7 @@ void Init()
CoreTiming::ScheduleEvent(VideoInterface::GetTicksPerHalfLine(), et_VI); CoreTiming::ScheduleEvent(VideoInterface::GetTicksPerHalfLine(), et_VI);
CoreTiming::ScheduleEvent(0, et_DSP); CoreTiming::ScheduleEvent(0, et_DSP);
CoreTiming::ScheduleEvent(s_audio_dma_period, et_AudioDMA); CoreTiming::ScheduleEvent(s_audio_dma_period, et_AudioDMA);
CoreTiming::ScheduleEvent(0, et_Throttle, Common::Timer::GetTimeMs()); CoreTiming::ScheduleEvent(0, et_Throttle, Common::Timer::GetTimeUs());
CoreTiming::ScheduleEvent(VideoInterface::GetTicksPerField(), et_PatchEngine); CoreTiming::ScheduleEvent(VideoInterface::GetTicksPerField(), et_PatchEngine);