diff options
author | ameerj <52414509+ameerj@users.noreply.github.com> | 2021-05-16 02:34:20 +0200 |
---|---|---|
committer | ameerj <52414509+ameerj@users.noreply.github.com> | 2021-05-16 02:34:20 +0200 |
commit | 5bef54618a2850e42f7bab45120dab9166468a25 (patch) | |
tree | adc5dbbe050488eb0d85b7a38a5c8310dca9ef92 /src/core/perf_stats.cpp | |
parent | Merge pull request #6300 from Morph1984/mbedtls (diff) | |
download | yuzu-5bef54618a2850e42f7bab45120dab9166468a25.tar yuzu-5bef54618a2850e42f7bab45120dab9166468a25.tar.gz yuzu-5bef54618a2850e42f7bab45120dab9166468a25.tar.bz2 yuzu-5bef54618a2850e42f7bab45120dab9166468a25.tar.lz yuzu-5bef54618a2850e42f7bab45120dab9166468a25.tar.xz yuzu-5bef54618a2850e42f7bab45120dab9166468a25.tar.zst yuzu-5bef54618a2850e42f7bab45120dab9166468a25.zip |
Diffstat (limited to 'src/core/perf_stats.cpp')
-rw-r--r-- | src/core/perf_stats.cpp | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/src/core/perf_stats.cpp b/src/core/perf_stats.cpp index c92337079..526c017cd 100644 --- a/src/core/perf_stats.cpp +++ b/src/core/perf_stats.cpp @@ -69,9 +69,7 @@ void PerfStats::EndSystemFrame() { } void PerfStats::EndGameFrame() { - std::lock_guard lock{object_mutex}; - - game_frames += 1; + game_frames.fetch_add(1, std::memory_order_relaxed); } double PerfStats::GetMeanFrametime() const { @@ -94,10 +92,11 @@ PerfStatsResults PerfStats::GetAndResetStats(microseconds current_system_time_us const auto interval = duration_cast<DoubleSecs>(now - reset_point).count(); const auto system_us_per_second = (current_system_time_us - reset_point_system_us) / interval; - + const auto current_frames = static_cast<double>(game_frames.load(std::memory_order_relaxed)); + const auto current_fps = current_frames / interval; const PerfStatsResults results{ .system_fps = static_cast<double>(system_frames) / interval, - .game_fps = static_cast<double>(game_frames) / interval, + .average_game_fps = (current_fps + previous_fps) / 2.0, .frametime = duration_cast<DoubleSecs>(accumulated_frametime).count() / static_cast<double>(system_frames), .emulation_speed = system_us_per_second.count() / 1'000'000.0, @@ -108,7 +107,8 @@ PerfStatsResults PerfStats::GetAndResetStats(microseconds current_system_time_us reset_point_system_us = current_system_time_us; accumulated_frametime = Clock::duration::zero(); system_frames = 0; - game_frames = 0; + game_frames.store(0, std::memory_order_relaxed); + previous_fps = current_fps; return results; } |