mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2025-01-14 23:34:07 +00:00
native_clock: Use RealTimeClock instead of SteadyClock
We want to synchronize RDTSC to real time.
This commit is contained in:
parent
6f9918552c
commit
c27a626b5b
1 changed files with 4 additions and 4 deletions
|
@ -53,11 +53,11 @@ u64 EstimateRDTSCFrequency() {
|
||||||
FencedRDTSC();
|
FencedRDTSC();
|
||||||
|
|
||||||
// Get the current time.
|
// Get the current time.
|
||||||
const auto start_time = Common::SteadyClock::Now();
|
const auto start_time = Common::RealTimeClock::Now();
|
||||||
const u64 tsc_start = FencedRDTSC();
|
const u64 tsc_start = FencedRDTSC();
|
||||||
// Wait for 250 milliseconds.
|
// Wait for 250 milliseconds.
|
||||||
std::this_thread::sleep_for(std::chrono::milliseconds{250});
|
std::this_thread::sleep_for(std::chrono::milliseconds{250});
|
||||||
const auto end_time = Common::SteadyClock::Now();
|
const auto end_time = Common::RealTimeClock::Now();
|
||||||
const u64 tsc_end = FencedRDTSC();
|
const u64 tsc_end = FencedRDTSC();
|
||||||
// Calculate differences.
|
// Calculate differences.
|
||||||
const u64 timer_diff = static_cast<u64>(
|
const u64 timer_diff = static_cast<u64>(
|
||||||
|
@ -75,13 +75,13 @@ NativeClock::NativeClock(u64 emulated_cpu_frequency_, u64 emulated_clock_frequen
|
||||||
// Thread to re-adjust the RDTSC frequency after 30 seconds has elapsed.
|
// Thread to re-adjust the RDTSC frequency after 30 seconds has elapsed.
|
||||||
time_sync_thread = std::jthread{[this](std::stop_token token) {
|
time_sync_thread = std::jthread{[this](std::stop_token token) {
|
||||||
// Get the current time.
|
// Get the current time.
|
||||||
const auto start_time = Common::SteadyClock::Now();
|
const auto start_time = Common::RealTimeClock::Now();
|
||||||
const u64 tsc_start = FencedRDTSC();
|
const u64 tsc_start = FencedRDTSC();
|
||||||
// Wait for 30 seconds.
|
// Wait for 30 seconds.
|
||||||
if (!Common::StoppableTimedWait(token, std::chrono::seconds{30})) {
|
if (!Common::StoppableTimedWait(token, std::chrono::seconds{30})) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const auto end_time = Common::SteadyClock::Now();
|
const auto end_time = Common::RealTimeClock::Now();
|
||||||
const u64 tsc_end = FencedRDTSC();
|
const u64 tsc_end = FencedRDTSC();
|
||||||
// Calculate differences.
|
// Calculate differences.
|
||||||
const u64 timer_diff = static_cast<u64>(
|
const u64 timer_diff = static_cast<u64>(
|
||||||
|
|
Loading…
Reference in a new issue