/** @file | |
CPUID Leaf 0x15 for Core Crystal Clock frequency instance as Base Timer Library. | |
Copyright (c) 2019 Intel Corporation. All rights reserved.<BR> | |
SPDX-License-Identifier: BSD-2-Clause-Patent | |
**/ | |
#include <Base.h> | |
#include <Library/TimerLib.h> | |
#include <Library/BaseLib.h> | |
/** | |
CPUID Leaf 0x15 for Core Crystal Clock Frequency. | |
The TSC counting frequency is determined by using CPUID leaf 0x15. Frequency in MHz = Core XTAL frequency * EBX/EAX. | |
In newer flavors of the CPU, core xtal frequency is returned in ECX or 0 if not supported. | |
@return The number of TSC counts per second. | |
**/ | |
UINT64 | |
CpuidCoreClockCalculateTscFrequency ( | |
VOID | |
); | |
/** | |
Internal function to retrieves the 64-bit frequency in Hz. | |
Internal function to retrieves the 64-bit frequency in Hz. | |
@return The frequency in Hz. | |
**/ | |
UINT64 | |
InternalGetPerformanceCounterFrequency ( | |
VOID | |
) | |
{ | |
return CpuidCoreClockCalculateTscFrequency (); | |
} |