diff options
Diffstat (limited to 'ReferenceCode/Haswell/CpuInit/Dxe/MachineCheck.h')
-rw-r--r-- | ReferenceCode/Haswell/CpuInit/Dxe/MachineCheck.h | 109 |
1 files changed, 109 insertions, 0 deletions
diff --git a/ReferenceCode/Haswell/CpuInit/Dxe/MachineCheck.h b/ReferenceCode/Haswell/CpuInit/Dxe/MachineCheck.h new file mode 100644 index 0000000..107c849 --- /dev/null +++ b/ReferenceCode/Haswell/CpuInit/Dxe/MachineCheck.h @@ -0,0 +1,109 @@ +/** @file + The header file for Machine check register initialization driver + +@copyright + Copyright (c) 1999 - 2012 Intel Corporation. All rights reserved + This software and associated documentation (if any) is furnished + under a license and may only be used or copied in accordance + with the terms of the license. Except as permitted by such + license, no part of this software or documentation may be + reproduced, stored in a retrieval system, or transmitted in any + form or by any means without the express written consent of + Intel Corporation. + + This file contains an 'Intel Peripheral Driver' and is + licensed for Intel CPUs and chipsets under the terms of your + license agreement with Intel or your vendor. This file may + be modified by the user, subject to additional terms of the + license agreement +**/ +#ifndef _MACHINE_CHECK_INIT_H +#define _MACHINE_CHECK_INIT_H + +#include "CpuInitDxe.h" +#include "MpCommon.h" + +#pragma pack(1) + +typedef struct { + UINT32 FPU : 1; + UINT32 VME : 1; + UINT32 DE : 1; + UINT32 PSE : 1; + UINT32 TSC : 1; + UINT32 MSR : 1; + UINT32 PAE : 1; + UINT32 MCE : 1; + + UINT32 CX8 : 1; + UINT32 APIC : 1; + UINT32 Reserved0 : 1; + UINT32 SEP : 1; + UINT32 MTRR : 1; + UINT32 PGE : 1; + UINT32 MCA : 1; + UINT32 CMOV : 1; + + UINT32 PAT : 1; + UINT32 PSE_36 : 1; + UINT32 PSN : 1; + UINT32 CLFSH : 1; + UINT32 Reserved1 : 1; + UINT32 DS : 1; + UINT32 ACPI : 1; + UINT32 MMX : 1; + + UINT32 FXSR : 1; + UINT32 SSE : 1; + UINT32 SSE2 : 1; + UINT32 SS : 1; + UINT32 HTT : 1; + UINT32 TM : 1; + UINT32 Reserved2 : 1; + UINT32 PBE : 1; +} CPU_FEATURE; + +typedef struct { + UINT32 Count : 8; + UINT32 MCG_CTL_P : 1; + UINT32 MCG_EXT_P : 1; + UINT32 EXT_CORR_ERR : 1; + UINT32 MCG_TES_P : 1; + UINT32 Reserved0 : 4; + UINT32 MCG_EXT_CNT : 8; + UINT32 Reserved1 : 8; +} CPU_IA32_MCG_CAP_LOW_REGISTER; + +#pragma pack() + +/** + Initialize all the Machine-Check registers. + + @param[in] Buffer - Pointer to private data. Not Used. + @param[in] MchkEnable - Enable Mchk or not. +**/ +VOID +InitializeMachineCheckRegisters ( + IN VOID *Buffer, + IN BOOLEAN MchkEnable + ); + +/** + Enable MCE feature for current CPU. + + @param[in] MchkEnable - Enable Mchk or not. +**/ +VOID +InitializeMce ( + IN BOOLEAN MchkEnable + ); + +/** + Enable "Machine Check Enable" +**/ +VOID +EnableMce ( + VOID + ); + +#endif |