2007-07-02 11:34:25 +02:00
|
|
|
/** @file
|
|
|
|
CpuBreakpoint 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-07-02 11:34:25 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2008-07-25 14:21:57 +02:00
|
|
|
/**
|
|
|
|
Microsoft Visual Studio 7.1 Function Prototypes for I/O Intrinsics.
|
|
|
|
**/
|
2008-10-24 10:18:36 +02:00
|
|
|
|
2021-03-12 11:05:07 +01:00
|
|
|
#include <Library/RegisterFilterLib.h>
|
|
|
|
|
2007-07-02 11:34:25 +02:00
|
|
|
unsigned __int64 __readmsr (int register);
|
|
|
|
|
|
|
|
#pragma intrinsic(__readmsr)
|
|
|
|
|
2008-07-25 14:21:57 +02:00
|
|
|
/**
|
|
|
|
Read data to MSR.
|
|
|
|
|
|
|
|
@param Index Register index of MSR.
|
|
|
|
|
|
|
|
@return Value read from MSR.
|
|
|
|
|
|
|
|
**/
|
2007-07-02 11:34:25 +02:00
|
|
|
UINT64
|
|
|
|
EFIAPI
|
|
|
|
AsmReadMsr64 (
|
|
|
|
IN UINT32 Index
|
|
|
|
)
|
|
|
|
{
|
2021-03-12 11:05:07 +01:00
|
|
|
UINT64 Value;
|
|
|
|
BOOLEAN Flag;
|
|
|
|
|
|
|
|
Flag = FilterBeforeMsrRead (Index, &Value);
|
|
|
|
if (Flag) {
|
|
|
|
Value = __readmsr (Index);
|
|
|
|
}
|
|
|
|
FilterAfterMsrRead (Index, &Value);
|
|
|
|
|
|
|
|
return Value;
|
2007-07-02 11:34:25 +02:00
|
|
|
}
|
|
|
|
|