Merge pull request #934 from lioncash/chrono

core_timing: Make GetGlobalTimeUs() return std::chrono::microseconds
pull/8/head
bunnei 7 years ago committed by GitHub
commit 83ef37ca37
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -226,8 +226,8 @@ void Idle() {
downcount = 0; downcount = 0;
} }
u64 GetGlobalTimeUs() { std::chrono::microseconds GetGlobalTimeUs() {
return GetTicks() * 1000000 / BASE_CLOCK_RATE; return std::chrono::microseconds{GetTicks() * 1000000 / BASE_CLOCK_RATE};
} }
int GetDowncount() { int GetDowncount() {

@ -17,6 +17,7 @@
* ScheduleEvent(periodInCycles - cyclesLate, callback, "whatever") * ScheduleEvent(periodInCycles - cyclesLate, callback, "whatever")
*/ */
#include <chrono>
#include <functional> #include <functional>
#include <string> #include <string>
#include "common/common_types.h" #include "common/common_types.h"
@ -86,7 +87,7 @@ void ClearPendingEvents();
void ForceExceptionCheck(s64 cycles); void ForceExceptionCheck(s64 cycles);
u64 GetGlobalTimeUs(); std::chrono::microseconds GetGlobalTimeUs();
int GetDowncount(); int GetDowncount();

@ -40,22 +40,21 @@ void PerfStats::EndGameFrame() {
game_frames += 1; game_frames += 1;
} }
PerfStats::Results PerfStats::GetAndResetStats(u64 current_system_time_us) { PerfStats::Results PerfStats::GetAndResetStats(microseconds current_system_time_us) {
std::lock_guard<std::mutex> lock(object_mutex); std::lock_guard<std::mutex> lock(object_mutex);
auto now = Clock::now(); const auto now = Clock::now();
// Walltime elapsed since stats were reset // Walltime elapsed since stats were reset
auto interval = duration_cast<DoubleSecs>(now - reset_point).count(); const auto interval = duration_cast<DoubleSecs>(now - reset_point).count();
auto system_us_per_second = const auto system_us_per_second = (current_system_time_us - reset_point_system_us) / interval;
static_cast<double>(current_system_time_us - reset_point_system_us) / interval;
Results results{}; Results results{};
results.system_fps = static_cast<double>(system_frames) / interval; results.system_fps = static_cast<double>(system_frames) / interval;
results.game_fps = static_cast<double>(game_frames) / interval; results.game_fps = static_cast<double>(game_frames) / interval;
results.frametime = duration_cast<DoubleSecs>(accumulated_frametime).count() / results.frametime = duration_cast<DoubleSecs>(accumulated_frametime).count() /
static_cast<double>(system_frames); static_cast<double>(system_frames);
results.emulation_speed = system_us_per_second / 1'000'000.0; results.emulation_speed = system_us_per_second.count() / 1'000'000.0;
// Reset counters // Reset counters
reset_point = now; reset_point = now;
@ -74,10 +73,10 @@ double PerfStats::GetLastFrameTimeScale() {
return duration_cast<DoubleSecs>(previous_frame_length).count() / FRAME_LENGTH; return duration_cast<DoubleSecs>(previous_frame_length).count() / FRAME_LENGTH;
} }
void FrameLimiter::DoFrameLimiting(u64 current_system_time_us) { void FrameLimiter::DoFrameLimiting(microseconds current_system_time_us) {
// Max lag caused by slow frames. Can be adjusted to compensate for too many slow frames. Higher // Max lag caused by slow frames. Can be adjusted to compensate for too many slow frames. Higher
// values increase the time needed to recover and limit framerate again after spikes. // values increase the time needed to recover and limit framerate again after spikes.
constexpr microseconds MAX_LAG_TIME_US = 25ms; constexpr microseconds MAX_LAG_TIME_US = 25us;
if (!Settings::values.toggle_framelimit) { if (!Settings::values.toggle_framelimit) {
return; return;
@ -85,7 +84,7 @@ void FrameLimiter::DoFrameLimiting(u64 current_system_time_us) {
auto now = Clock::now(); auto now = Clock::now();
frame_limiting_delta_err += microseconds(current_system_time_us - previous_system_time_us); frame_limiting_delta_err += current_system_time_us - previous_system_time_us;
frame_limiting_delta_err -= duration_cast<microseconds>(now - previous_walltime); frame_limiting_delta_err -= duration_cast<microseconds>(now - previous_walltime);
frame_limiting_delta_err = frame_limiting_delta_err =
std::clamp(frame_limiting_delta_err, -MAX_LAG_TIME_US, MAX_LAG_TIME_US); std::clamp(frame_limiting_delta_err, -MAX_LAG_TIME_US, MAX_LAG_TIME_US);

@ -33,7 +33,7 @@ public:
void EndSystemFrame(); void EndSystemFrame();
void EndGameFrame(); void EndGameFrame();
Results GetAndResetStats(u64 current_system_time_us); Results GetAndResetStats(std::chrono::microseconds current_system_time_us);
/** /**
* Gets the ratio between walltime and the emulated time of the previous system frame. This is * Gets the ratio between walltime and the emulated time of the previous system frame. This is
@ -47,7 +47,7 @@ private:
/// Point when the cumulative counters were reset /// Point when the cumulative counters were reset
Clock::time_point reset_point = Clock::now(); Clock::time_point reset_point = Clock::now();
/// System time when the cumulative counters were reset /// System time when the cumulative counters were reset
u64 reset_point_system_us = 0; std::chrono::microseconds reset_point_system_us{0};
/// Cumulative duration (excluding v-sync/frame-limiting) of frames since last reset /// Cumulative duration (excluding v-sync/frame-limiting) of frames since last reset
Clock::duration accumulated_frametime = Clock::duration::zero(); Clock::duration accumulated_frametime = Clock::duration::zero();
@ -68,11 +68,11 @@ class FrameLimiter {
public: public:
using Clock = std::chrono::high_resolution_clock; using Clock = std::chrono::high_resolution_clock;
void DoFrameLimiting(u64 current_system_time_us); void DoFrameLimiting(std::chrono::microseconds current_system_time_us);
private: private:
/// Emulated system time (in microseconds) at the last limiter invocation /// Emulated system time (in microseconds) at the last limiter invocation
u64 previous_system_time_us = 0; std::chrono::microseconds previous_system_time_us{0};
/// Walltime at the last limiter invocation /// Walltime at the last limiter invocation
Clock::time_point previous_walltime = Clock::now(); Clock::time_point previous_walltime = Clock::now();

Loading…
Cancel
Save