mirror of https://github.com/acidanthera/audk.git
68 lines
1.6 KiB
C
68 lines
1.6 KiB
C
/** @file
|
|
AsmReadMsr64 function
|
|
|
|
Copyright (c) 2006 - 2021, Intel Corporation. All rights reserved.<BR>
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include <Library/RegisterFilterLib.h>
|
|
|
|
/**
|
|
Returns a 64-bit Machine Specific Register(MSR).
|
|
|
|
Reads and returns the 64-bit MSR specified by Index. No parameter checking is
|
|
performed on Index, and some Index values may cause CPU exceptions. The
|
|
caller must either guarantee that Index is valid, or the caller must set up
|
|
exception handlers to catch the exceptions. This function is only available
|
|
on IA-32 and x64.
|
|
|
|
@param Index The 32-bit MSR index to read.
|
|
|
|
@return The value of the MSR identified by Index.
|
|
|
|
**/
|
|
UINT64
|
|
AsmReadMsr64Internal (
|
|
IN UINT32 Index
|
|
)
|
|
{
|
|
_asm {
|
|
mov ecx, Index
|
|
rdmsr
|
|
}
|
|
}
|
|
|
|
/**
|
|
Returns a 64-bit Machine Specific Register(MSR).
|
|
|
|
Reads and returns the 64-bit MSR specified by Index. No parameter checking is
|
|
performed on Index, and some Index values may cause CPU exceptions. The
|
|
caller must either guarantee that Index is valid, or the caller must set up
|
|
exception handlers to catch the exceptions. This function is only available
|
|
on IA-32 and x64.
|
|
|
|
@param Index The 32-bit MSR index to read.
|
|
|
|
@return The value of the MSR identified by Index.
|
|
|
|
**/
|
|
UINT64
|
|
EFIAPI
|
|
AsmReadMsr64 (
|
|
IN UINT32 Index
|
|
)
|
|
{
|
|
UINT64 Value;
|
|
BOOLEAN Flag;
|
|
|
|
Flag = FilterBeforeMsrRead (Index, &Value);
|
|
if (Flag) {
|
|
Value = AsmReadMsr64Internal (Index);
|
|
}
|
|
|
|
FilterAfterMsrRead (Index, &Value);
|
|
|
|
return Value;
|
|
}
|