From 2325f3799b159d6165c7188b0fd9db659f6f61b7 Mon Sep 17 00:00:00 2001 From: SergeySlice Date: Mon, 11 Dec 2023 20:18:48 +0300 Subject: [PATCH] new cpu 12th, 13th Signed-off-by: SergeySlice --- Include/IndustryStandard/ProcessorInfo.h | 16 +++++++------ rEFIt_UEFI/Platform/StateGenerator.cpp | 6 ++++- rEFIt_UEFI/Platform/cpu.cpp | 29 ++++++++++++++++-------- rEFIt_UEFI/Platform/cpu.h | 5 +++- 4 files changed, 38 insertions(+), 18 deletions(-) diff --git a/Include/IndustryStandard/ProcessorInfo.h b/Include/IndustryStandard/ProcessorInfo.h index 4e13b9e617..1a1cd04b70 100755 --- a/Include/IndustryStandard/ProcessorInfo.h +++ b/Include/IndustryStandard/ProcessorInfo.h @@ -195,13 +195,15 @@ enum { #define CPU_MODEL_COMETLAKE_Y 0xA5 /* aka 10th generation Amber Lake Y */ #define CPU_MODEL_COMETLAKE_U 0xA6 //From Clover collection -#define CPU_MODEL_ATOM_TM 0x86 /* Tremont */ -#define CPU_MODEL_TIGERLAKE_C 0x8C /* 11h generation Tiger Lake */ -#define CPU_MODEL_TIGERLAKE_D 0x8D /* 11h generation Tiger Lake */ -#define CPU_MODEL_ALDERLAKE 0x97 /* 12h generation Alder Lake */ -#define CPU_MODEL_ROCKETLAKE 0xA7 /* 11h Rocket Lake */ -#define CPU_MODEL_RAPTORLAKE 0xB7 /* 13h Raptor Lake */ -#define CPU_MODEL_METEORLAKE 0xAA /* 14h Meteor Lake */ +#define CPU_MODEL_ATOM_TM 0x86 /* Tremont */ +#define CPU_MODEL_TIGERLAKE_C 0x8C /* 11h generation Tiger Lake */ +#define CPU_MODEL_TIGERLAKE_D 0x8D /* 11h generation Tiger Lake */ +#define CPU_MODEL_ALDERLAKE 0x97 /* 12h generation Alder Lake */ +#define CPU_MODEL_ALDERLAKE_ULT 0x9A /* 12h generation Alder Lake, i5-12500h */ +#define CPU_MODEL_ROCKETLAKE 0xA7 /* 11h Rocket Lake */ +#define CPU_MODEL_RAPTORLAKE 0xB7 /* 13h Raptor Lake */ +#define CPU_MODEL_RAPTORLAKE_B 0xBF /* 13h Raptor Lake, i5-13400h */ +#define CPU_MODEL_METEORLAKE 0xAA /* 14h Meteor Lake */ #define CPU_SOCKET_UNKNOWN 0x02 #define CPU_SOCKET_PGA478 0x0F diff --git a/rEFIt_UEFI/Platform/StateGenerator.cpp b/rEFIt_UEFI/Platform/StateGenerator.cpp index 1f7170bf24..329937d3e4 100644 --- a/rEFIt_UEFI/Platform/StateGenerator.cpp +++ b/rEFIt_UEFI/Platform/StateGenerator.cpp @@ -275,8 +275,10 @@ SSDT_TABLE *generate_pss_ssdt(UINTN Number) case CPU_MODEL_COMETLAKE_U: case CPU_MODEL_TIGERLAKE_C: case CPU_MODEL_TIGERLAKE_D: - case CPU_MODEL_ALDERLAKE: case CPU_MODEL_ROCKETLAKE: + case CPU_MODEL_ALDERLAKE: + case CPU_MODEL_ALDERLAKE_ULT: + case CPU_MODEL_RAPTORLAKE_B: case CPU_MODEL_RAPTORLAKE: case CPU_MODEL_METEORLAKE: { @@ -350,6 +352,8 @@ SSDT_TABLE *generate_pss_ssdt(UINTN Number) (gCPUStructure.Model == CPU_MODEL_ROCKETLAKE) || (gCPUStructure.Model == CPU_MODEL_ALDERLAKE) || (gCPUStructure.Model == CPU_MODEL_RAPTORLAKE) || + (gCPUStructure.Model == CPU_MODEL_ALDERLAKE_ULT) || + (gCPUStructure.Model == CPU_MODEL_RAPTORLAKE_B) || (gCPUStructure.Model == CPU_MODEL_METEORLAKE) || (gCPUStructure.Model == CPU_MODEL_COMETLAKE_S) || (gCPUStructure.Model == CPU_MODEL_COMETLAKE_Y) || diff --git a/rEFIt_UEFI/Platform/cpu.cpp b/rEFIt_UEFI/Platform/cpu.cpp index 9acf81c5eb..4ed30804c1 100755 --- a/rEFIt_UEFI/Platform/cpu.cpp +++ b/rEFIt_UEFI/Platform/cpu.cpp @@ -326,9 +326,11 @@ void GetCPUProperties (void) case CPU_MODEL_COMETLAKE_U: case CPU_MODEL_TIGERLAKE_C: case CPU_MODEL_TIGERLAKE_D: - case CPU_MODEL_ALDERLAKE: case CPU_MODEL_ROCKETLAKE: + case CPU_MODEL_ALDERLAKE: case CPU_MODEL_RAPTORLAKE: + case CPU_MODEL_ALDERLAKE_ULT: + case CPU_MODEL_RAPTORLAKE_B: case CPU_MODEL_METEORLAKE: msr = AsmReadMsr64(MSR_CORE_THREAD_COUNT); //0x35 DBG("MSR 0x35 %16llX\n", msr); @@ -525,19 +527,22 @@ void GetCPUProperties (void) case CPU_MODEL_TIGERLAKE_D: case CPU_MODEL_ALDERLAKE: case CPU_MODEL_ROCKETLAKE: + case CPU_MODEL_ALDERLAKE_ULT: + case CPU_MODEL_RAPTORLAKE_B: case CPU_MODEL_RAPTORLAKE: case CPU_MODEL_METEORLAKE: gCPUStructure.TSCFrequency = MultU64x32(gCPUStructure.CurrentSpeed, Mega); //MHz -> Hz gCPUStructure.CPUFrequency = gCPUStructure.TSCFrequency; - - //----test C3 patch - msr = AsmReadMsr64(MSR_PKG_CST_CONFIG_CONTROL); //0xE2 - MsgLog("MSR 0xE2 before patch %08llX\n", msr); - if (msr & 0x8000) { - MsgLog("MSR 0xE2 is locked, PM patches will be turned on\n"); - GlobalConfig.NeedPMfix = true; + if (gCPUStructure.Model < 0x90) { + //----test C3 patch + msr = AsmReadMsr64(MSR_PKG_CST_CONFIG_CONTROL); //0xE2 + MsgLog("MSR 0xE2 before patch %08llX\n", msr); + if (msr & 0x8000) { + MsgLog("MSR 0xE2 is locked, PM patches will be turned on\n"); + GlobalConfig.NeedPMfix = true; + } } // AsmWriteMsr64(MSR_PKG_CST_CONFIG_CONTROL, (msr & 0x8000000ULL)); // msr = AsmReadMsr64(MSR_PKG_CST_CONFIG_CONTROL); @@ -556,7 +561,8 @@ void GetCPUProperties (void) MsgLog(" EIST is locked and %s\n", (msr & _Bit(16))?"enabled":"disabled"); } - if (gCPUStructure.Model != CPU_MODEL_GOLDMONT && gCPUStructure.Model != CPU_MODEL_AIRMONT && + if (gCPUStructure.Model != CPU_MODEL_GOLDMONT && + gCPUStructure.Model != CPU_MODEL_AIRMONT && gCPUStructure.Model != CPU_MODEL_AVOTON) { msr = AsmReadMsr64(MSR_FLEX_RATIO); //0x194 if ((RShiftU64(msr, 16) & 0x01) != 0) { @@ -1405,6 +1411,8 @@ UINT16 GetAdvancedCpuType() case CPU_MODEL_TIGERLAKE_C: case CPU_MODEL_TIGERLAKE_D: case CPU_MODEL_ALDERLAKE: + case CPU_MODEL_ALDERLAKE_ULT: + case CPU_MODEL_RAPTORLAKE_B: case CPU_MODEL_ROCKETLAKE: case CPU_MODEL_RAPTORLAKE: case CPU_MODEL_METEORLAKE: @@ -1656,7 +1664,10 @@ MacModel GetDefaultModel() DefaultType = MacPro61; break; case CPU_MODEL_ALDERLAKE: + case CPU_MODEL_ALDERLAKE_ULT: //??? + case CPU_MODEL_RAPTORLAKE_B: case CPU_MODEL_COMETLAKE_S: + case CPU_MODEL_ROCKETLAKE: case CPU_MODEL_RAPTORLAKE: case CPU_MODEL_METEORLAKE: DefaultType = MacPro71; diff --git a/rEFIt_UEFI/Platform/cpu.h b/rEFIt_UEFI/Platform/cpu.h index bdaef36540..6ec56b5ee9 100644 --- a/rEFIt_UEFI/Platform/cpu.h +++ b/rEFIt_UEFI/Platform/cpu.h @@ -72,14 +72,17 @@ #define CPU_MODEL_TIGERLAKE_D 0x8D /* 11h generation Tiger Lake */ #define CPU_MODEL_KABYLAKE1 0x8E /* 7h Kabylake Mobile */ #define CPU_MODEL_ALDERLAKE 0x97 /* 12h generation Alder Lake */ +#define CPU_MODEL_ALDERLAKE_ULT 0x9A /* 12h generation Alder Lake, i5-12500h */ #define CPU_MODEL_KABYLAKE2 0x9E /* 7h CoffeeLake */ #undef CPU_MODEL_COMETLAKE_S // Jief : mistake in ProcessorInfo.h ? #define CPU_MODEL_COMETLAKE_S 0x9F /* desktop Comet Lake */ #define CPU_MODEL_COMETLAKE_Y 0xA5 /* 10h Comet Lake */ #define CPU_MODEL_COMETLAKE_U 0xA6 /* 10h Comet Lake */ #define CPU_MODEL_ROCKETLAKE 0xA7 /* 11h Rocket Lake */ +#define CPU_MODEL_METEORLAKE 0xAA /* 14h Meteor Lake */ #define CPU_MODEL_RAPTORLAKE 0xB7 /* 13h Raptor Lake */ -#define CPU_MODEL_METEORLAKE 0xAA +#define CPU_MODEL_RAPTORLAKE_B 0xBF /* 13h Raptor Lake, i5-13400h */ + #define CPU_VENDOR_INTEL 0x756E6547 #define CPU_VENDOR_AMD 0x68747541