diff options
author | Morph <39850852+Morph1984@users.noreply.github.com> | 2022-01-30 18:57:23 +0100 |
---|---|---|
committer | Morph <39850852+Morph1984@users.noreply.github.com> | 2022-01-30 18:57:23 +0100 |
commit | 6267110b694d3b3f8a8561c61ad6b4a4548873b5 (patch) | |
tree | 5255d1ef13ff15fd65c4dfa535b366856cbd8c85 /src/common/wall_clock.cpp | |
parent | common: wall_clock: Utilize constants for ms, us, and ns ratios (diff) | |
download | yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.tar yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.tar.gz yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.tar.bz2 yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.tar.lz yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.tar.xz yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.tar.zst yuzu-6267110b694d3b3f8a8561c61ad6b4a4548873b5.zip |
Diffstat (limited to '')
-rw-r--r-- | src/common/wall_clock.cpp | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/src/common/wall_clock.cpp b/src/common/wall_clock.cpp index 081e0562f..9acf7551e 100644 --- a/src/common/wall_clock.cpp +++ b/src/common/wall_clock.cpp @@ -65,16 +65,20 @@ private: #ifdef ARCHITECTURE_x86_64 -std::unique_ptr<WallClock> CreateBestMatchingClock(u32 emulated_cpu_frequency, - u32 emulated_clock_frequency) { +std::unique_ptr<WallClock> CreateBestMatchingClock(u64 emulated_cpu_frequency, + u64 emulated_clock_frequency) { const auto& caps = GetCPUCaps(); u64 rtsc_frequency = 0; if (caps.invariant_tsc) { rtsc_frequency = EstimateRDTSCFrequency(); } - // Fallback to StandardWallClock if the hardware TSC does not have nanosecond precision. - if (rtsc_frequency <= WallClock::NS_RATIO) { + // Fallback to StandardWallClock if the hardware TSC does not have the precision greater than: + // - A nanosecond + // - The emulated CPU frequency + // - The emulated clock counter frequency (CNTFRQ) + if (rtsc_frequency <= WallClock::NS_RATIO || rtsc_frequency <= emulated_cpu_frequency || + rtsc_frequency <= emulated_clock_frequency) { return std::make_unique<StandardWallClock>(emulated_cpu_frequency, emulated_clock_frequency); } else { @@ -85,8 +89,8 @@ std::unique_ptr<WallClock> CreateBestMatchingClock(u32 emulated_cpu_frequency, #else -std::unique_ptr<WallClock> CreateBestMatchingClock(u32 emulated_cpu_frequency, - u32 emulated_clock_frequency) { +std::unique_ptr<WallClock> CreateBestMatchingClock(u64 emulated_cpu_frequency, + u64 emulated_clock_frequency) { return std::make_unique<StandardWallClock>(emulated_cpu_frequency, emulated_clock_frequency); } |