#define SMM_FEATURES_LIB_IA32_CORE_SMRR_PHYSMASK 0x0A1\r
#define EFI_MSR_SMRR_MASK 0xFFFFF000\r
#define EFI_MSR_SMRR_PHYS_MASK_VALID BIT11\r
+#define SMM_FEATURES_LIB_SMM_FEATURE_CONTROL 0x4E0\r
\r
//\r
// Set default value to assume SMRR is not supported\r
//\r
BOOLEAN mSmrrSupported = FALSE;\r
\r
+//\r
+// Set default value to assume MSR_SMM_FEATURE_CONTROL is not supported\r
+//\r
+BOOLEAN mSmmFeatureControlSupported = FALSE;\r
+\r
//\r
// Set default value to assume IA-32 Architectural MSRs are used\r
//\r
}\r
}\r
\r
+ //\r
+ // Intel(R) 64 and IA-32 Architectures Software Developer's Manual\r
+ // Volume 3C, Section 35.10.1 MSRs in 4th Generation Intel(R) Core(TM)\r
+ // Processor Family\r
+ //\r
+ // If CPU Family/Model is 06_3C, 06_45, or 06_46 then use 4th Generation\r
+ // Intel(R) Core(TM) Processor Family MSRs\r
+ //\r
+ if (FamilyId == 0x06) {\r
+ if (ModelId == 0x3C || ModelId == 0x45 || ModelId == 0x46) {\r
+ mSmmFeatureControlSupported = TRUE;\r
+ }\r
+ }\r
+\r
//\r
// Intel(R) 64 and IA-32 Architectures Software Developer's Manual\r
// Volume 3C, Section 34.4.2 SMRAM Caching\r
IN SMM_REG_NAME RegName\r
)\r
{\r
+ if (mSmmFeatureControlSupported && RegName == SmmRegFeatureControl) {\r
+ return TRUE;\r
+ }\r
return FALSE;\r
}\r
\r
IN SMM_REG_NAME RegName\r
)\r
{\r
+ if (mSmmFeatureControlSupported && RegName == SmmRegFeatureControl) {\r
+ return AsmReadMsr64 (SMM_FEATURES_LIB_SMM_FEATURE_CONTROL);\r
+ }\r
return 0;\r
}\r
\r
IN UINT64 Value\r
)\r
{\r
+ if (mSmmFeatureControlSupported && RegName == SmmRegFeatureControl) {\r
+ AsmWriteMsr64 (SMM_FEATURES_LIB_SMM_FEATURE_CONTROL, Value);\r
+ }\r
}\r
\r
/**\r