2007-06-22 05:21:45 +02:00
|
|
|
/** @file
|
|
|
|
AsmReadMsr64 function
|
|
|
|
|
2021-03-12 11:05:07 +01:00
|
|
|
Copyright (c) 2006 - 2021, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-22 05:21:45 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2008-09-17 09:46:17 +02:00
|
|
|
|
2021-03-12 11:05:07 +01:00
|
|
|
#include <Library/RegisterFilterLib.h>
|
2007-06-22 05:21:45 +02:00
|
|
|
|
2008-07-25 14:21:57 +02:00
|
|
|
/**
|
|
|
|
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
|
2008-12-05 04:23:13 +01:00
|
|
|
on IA-32 and x64.
|
2008-07-25 14:21:57 +02:00
|
|
|
|
|
|
|
@param Index The 32-bit MSR index to read.
|
|
|
|
|
|
|
|
@return The value of the MSR identified by Index.
|
|
|
|
|
|
|
|
**/
|
2007-06-22 05:21:45 +02:00
|
|
|
UINT64
|
2021-03-12 11:05:07 +01:00
|
|
|
AsmReadMsr64Internal (
|
2007-06-22 05:21:45 +02:00
|
|
|
IN UINT32 Index
|
|
|
|
)
|
|
|
|
{
|
|
|
|
_asm {
|
|
|
|
mov ecx, Index
|
|
|
|
rdmsr
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-12 11:05:07 +01:00
|
|
|
/**
|
|
|
|
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;
|
|
|
|
}
|