Merge pull request #7494 from Morph1984/no-time-to-wait

native_clock: Wait for less time in EstimateRDTSCFrequency
This commit is contained in:
Fernando S 2021-12-05 18:56:38 +01:00 committed by GitHub
commit f1f91ad468
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -15,26 +15,26 @@
namespace Common { namespace Common {
u64 EstimateRDTSCFrequency() { u64 EstimateRDTSCFrequency() {
const auto milli_10 = std::chrono::milliseconds{10}; // Discard the first result measuring the rdtsc.
// get current time
_mm_mfence(); _mm_mfence();
const u64 tscStart = __rdtsc(); __rdtsc();
const auto startTime = std::chrono::steady_clock::now(); std::this_thread::sleep_for(std::chrono::milliseconds{1});
// wait roughly 3 seconds
while (true) {
auto milli = std::chrono::duration_cast<std::chrono::milliseconds>(
std::chrono::steady_clock::now() - startTime);
if (milli.count() >= 3000)
break;
std::this_thread::sleep_for(milli_10);
}
const auto endTime = std::chrono::steady_clock::now();
_mm_mfence(); _mm_mfence();
const u64 tscEnd = __rdtsc(); __rdtsc();
// calculate difference
const u64 timer_diff = // Get the current time.
std::chrono::duration_cast<std::chrono::nanoseconds>(endTime - startTime).count(); const auto start_time = std::chrono::steady_clock::now();
const u64 tsc_diff = tscEnd - tscStart; _mm_mfence();
const u64 tsc_start = __rdtsc();
// Wait for 200 milliseconds.
std::this_thread::sleep_for(std::chrono::milliseconds{200});
const auto end_time = std::chrono::steady_clock::now();
_mm_mfence();
const u64 tsc_end = __rdtsc();
// Calculate differences.
const u64 timer_diff = static_cast<u64>(
std::chrono::duration_cast<std::chrono::nanoseconds>(end_time - start_time).count());
const u64 tsc_diff = tsc_end - tsc_start;
const u64 tsc_freq = MultiplyAndDivide64(tsc_diff, 1000000000ULL, timer_diff); const u64 tsc_freq = MultiplyAndDivide64(tsc_diff, 1000000000ULL, timer_diff);
return tsc_freq; return tsc_freq;
} }