mirror of https://github.com/acidanthera/audk.git
UefiCpuPkg: Shadow microcode patch according to FIT microcode entry.
The existing MpInitLib will shadow the microcode update patches from flash to memory and this is done by searching microcode region specified by PCD PcdCpuMicrocodePatchAddress and PcdCpuMicrocodePatchRegionSize. This brings a limition to platform FW that all the microcode patches must be placed in one continuous flash space. This patch shadows microcode update according to FIT microcode entries if it's present, otherwise it will fallback to original logic (by PCD). A new featured PCD gUefiCpuPkgTokenSpaceGuid.PcdCpuShadowMicrocodeByFit is added for enabling/disabling this support. TEST: Tested on FIT enabled platform. BZ: https://tianocore.acgmultimedia.com/show_bug.cgi?id=2449 Cc: Eric Dong <eric.dong@intel.com> Cc: Ray Ni <ray.ni@intel.com> Cc: Laszlo Ersek <lersek@redhat.com> Signed-off-by: Siyuan Fu <siyuan.fu@intel.com> Reviewed-by: Eric Dong <eric.dong@intel.com> Reviewed-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
parent
c7c964b109
commit
dd01704111
|
@ -68,5 +68,6 @@
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuMicrocodePatchRegionSize ## CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuMicrocodePatchRegionSize ## CONSUMES
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuApLoopMode ## CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuApLoopMode ## CONSUMES
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuApTargetCstate ## SOMETIMES_CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuApTargetCstate ## SOMETIMES_CONSUMES
|
||||||
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuShadowMicrocodeByFit ## CONSUMES
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdCpuStackGuard ## CONSUMES
|
gEfiMdeModulePkgTokenSpaceGuid.PcdCpuStackGuard ## CONSUMES
|
||||||
|
|
||||||
|
|
|
@ -318,7 +318,7 @@ Done:
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Determine if a microcode patch will be loaded into memory.
|
Determine if a microcode patch matchs the specific processor signature and flag.
|
||||||
|
|
||||||
@param[in] CpuMpData The pointer to CPU MP Data structure.
|
@param[in] CpuMpData The pointer to CPU MP Data structure.
|
||||||
@param[in] ProcessorSignature The processor signature field value
|
@param[in] ProcessorSignature The processor signature field value
|
||||||
|
@ -330,7 +330,7 @@ Done:
|
||||||
@retval FALSE The specified microcode patch will not be loaded.
|
@retval FALSE The specified microcode patch will not be loaded.
|
||||||
**/
|
**/
|
||||||
BOOLEAN
|
BOOLEAN
|
||||||
IsMicrocodePatchNeedLoad (
|
IsProcessorMatchedMicrocodePatch (
|
||||||
IN CPU_MP_DATA *CpuMpData,
|
IN CPU_MP_DATA *CpuMpData,
|
||||||
IN UINT32 ProcessorSignature,
|
IN UINT32 ProcessorSignature,
|
||||||
IN UINT32 ProcessorFlags
|
IN UINT32 ProcessorFlags
|
||||||
|
@ -351,7 +351,77 @@ IsMicrocodePatchNeedLoad (
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Actual worker function that loads the required microcode patches into memory.
|
Check the 'ProcessorSignature' and 'ProcessorFlags' of the microcode
|
||||||
|
patch header with the CPUID and PlatformID of the processors within
|
||||||
|
system to decide if it will be copied into memory.
|
||||||
|
|
||||||
|
@param[in] CpuMpData The pointer to CPU MP Data structure.
|
||||||
|
@param[in] MicrocodeEntryPoint The pointer to the microcode patch header.
|
||||||
|
|
||||||
|
@retval TRUE The specified microcode patch need to be loaded.
|
||||||
|
@retval FALSE The specified microcode patch dosen't need to be loaded.
|
||||||
|
**/
|
||||||
|
BOOLEAN
|
||||||
|
IsMicrocodePatchNeedLoad (
|
||||||
|
IN CPU_MP_DATA *CpuMpData,
|
||||||
|
CPU_MICROCODE_HEADER *MicrocodeEntryPoint
|
||||||
|
)
|
||||||
|
{
|
||||||
|
BOOLEAN NeedLoad;
|
||||||
|
UINTN DataSize;
|
||||||
|
UINTN TotalSize;
|
||||||
|
CPU_MICROCODE_EXTENDED_TABLE_HEADER *ExtendedTableHeader;
|
||||||
|
UINT32 ExtendedTableCount;
|
||||||
|
CPU_MICROCODE_EXTENDED_TABLE *ExtendedTable;
|
||||||
|
UINTN Index;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Check the 'ProcessorSignature' and 'ProcessorFlags' in microcode patch header.
|
||||||
|
//
|
||||||
|
NeedLoad = IsProcessorMatchedMicrocodePatch (
|
||||||
|
CpuMpData,
|
||||||
|
MicrocodeEntryPoint->ProcessorSignature.Uint32,
|
||||||
|
MicrocodeEntryPoint->ProcessorFlags
|
||||||
|
);
|
||||||
|
|
||||||
|
//
|
||||||
|
// If the Extended Signature Table exists, check if the processor is in the
|
||||||
|
// support list
|
||||||
|
//
|
||||||
|
DataSize = MicrocodeEntryPoint->DataSize;
|
||||||
|
TotalSize = (DataSize == 0) ? 2048 : MicrocodeEntryPoint->TotalSize;
|
||||||
|
if ((!NeedLoad) && (DataSize != 0) &&
|
||||||
|
(TotalSize - DataSize > sizeof (CPU_MICROCODE_HEADER) +
|
||||||
|
sizeof (CPU_MICROCODE_EXTENDED_TABLE_HEADER))) {
|
||||||
|
ExtendedTableHeader = (CPU_MICROCODE_EXTENDED_TABLE_HEADER *) ((UINT8 *) (MicrocodeEntryPoint)
|
||||||
|
+ DataSize + sizeof (CPU_MICROCODE_HEADER));
|
||||||
|
ExtendedTableCount = ExtendedTableHeader->ExtendedSignatureCount;
|
||||||
|
ExtendedTable = (CPU_MICROCODE_EXTENDED_TABLE *) (ExtendedTableHeader + 1);
|
||||||
|
|
||||||
|
for (Index = 0; Index < ExtendedTableCount; Index ++) {
|
||||||
|
//
|
||||||
|
// Check the 'ProcessorSignature' and 'ProcessorFlag' of the Extended
|
||||||
|
// Signature Table entry with the CPUID and PlatformID of the processors
|
||||||
|
// within system to decide if it will be copied into memory
|
||||||
|
//
|
||||||
|
NeedLoad = IsProcessorMatchedMicrocodePatch (
|
||||||
|
CpuMpData,
|
||||||
|
ExtendedTable->ProcessorSignature.Uint32,
|
||||||
|
ExtendedTable->ProcessorFlag
|
||||||
|
);
|
||||||
|
if (NeedLoad) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
ExtendedTable ++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return NeedLoad;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Actual worker function that shadows the required microcode patches into memory.
|
||||||
|
|
||||||
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
||||||
@param[in] Patches The pointer to an array of information on
|
@param[in] Patches The pointer to an array of information on
|
||||||
|
@ -363,7 +433,7 @@ IsMicrocodePatchNeedLoad (
|
||||||
to be loaded.
|
to be loaded.
|
||||||
**/
|
**/
|
||||||
VOID
|
VOID
|
||||||
LoadMicrocodePatchWorker (
|
ShadowMicrocodePatchWorker (
|
||||||
IN OUT CPU_MP_DATA *CpuMpData,
|
IN OUT CPU_MP_DATA *CpuMpData,
|
||||||
IN MICROCODE_PATCH_INFO *Patches,
|
IN MICROCODE_PATCH_INFO *Patches,
|
||||||
IN UINTN PatchCount,
|
IN UINTN PatchCount,
|
||||||
|
@ -390,7 +460,6 @@ LoadMicrocodePatchWorker (
|
||||||
(VOID *) Patches[Index].Address,
|
(VOID *) Patches[Index].Address,
|
||||||
Patches[Index].Size
|
Patches[Index].Size
|
||||||
);
|
);
|
||||||
|
|
||||||
Walker += Patches[Index].Size;
|
Walker += Patches[Index].Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -410,12 +479,13 @@ LoadMicrocodePatchWorker (
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Load the required microcode patches data into memory.
|
Shadow the required microcode patches data into memory according to PCD
|
||||||
|
PcdCpuMicrocodePatchAddress and PcdCpuMicrocodePatchRegionSize.
|
||||||
|
|
||||||
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
||||||
**/
|
**/
|
||||||
VOID
|
VOID
|
||||||
LoadMicrocodePatch (
|
ShadowMicrocodePatchByPcd (
|
||||||
IN OUT CPU_MP_DATA *CpuMpData
|
IN OUT CPU_MP_DATA *CpuMpData
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
@ -423,15 +493,10 @@ LoadMicrocodePatch (
|
||||||
UINTN MicrocodeEnd;
|
UINTN MicrocodeEnd;
|
||||||
UINTN DataSize;
|
UINTN DataSize;
|
||||||
UINTN TotalSize;
|
UINTN TotalSize;
|
||||||
CPU_MICROCODE_EXTENDED_TABLE_HEADER *ExtendedTableHeader;
|
|
||||||
UINT32 ExtendedTableCount;
|
|
||||||
CPU_MICROCODE_EXTENDED_TABLE *ExtendedTable;
|
|
||||||
MICROCODE_PATCH_INFO *PatchInfoBuffer;
|
MICROCODE_PATCH_INFO *PatchInfoBuffer;
|
||||||
UINTN MaxPatchNumber;
|
UINTN MaxPatchNumber;
|
||||||
UINTN PatchCount;
|
UINTN PatchCount;
|
||||||
UINTN TotalLoadSize;
|
UINTN TotalLoadSize;
|
||||||
UINTN Index;
|
|
||||||
BOOLEAN NeedLoad;
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Initialize the microcode patch related fields in CpuMpData as the values
|
// Initialize the microcode patch related fields in CpuMpData as the values
|
||||||
|
@ -487,55 +552,7 @@ LoadMicrocodePatch (
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
if (IsMicrocodePatchNeedLoad (CpuMpData, MicrocodeEntryPoint)) {
|
||||||
// Check the 'ProcessorSignature' and 'ProcessorFlags' of the microcode
|
|
||||||
// patch header with the CPUID and PlatformID of the processors within
|
|
||||||
// system to decide if it will be copied into memory
|
|
||||||
//
|
|
||||||
NeedLoad = IsMicrocodePatchNeedLoad (
|
|
||||||
CpuMpData,
|
|
||||||
MicrocodeEntryPoint->ProcessorSignature.Uint32,
|
|
||||||
MicrocodeEntryPoint->ProcessorFlags
|
|
||||||
);
|
|
||||||
|
|
||||||
//
|
|
||||||
// If the Extended Signature Table exists, check if the processor is in the
|
|
||||||
// support list
|
|
||||||
//
|
|
||||||
if ((!NeedLoad) && (DataSize != 0) &&
|
|
||||||
(TotalSize - DataSize > sizeof (CPU_MICROCODE_HEADER) +
|
|
||||||
sizeof (CPU_MICROCODE_EXTENDED_TABLE_HEADER))) {
|
|
||||||
ExtendedTableHeader = (CPU_MICROCODE_EXTENDED_TABLE_HEADER *) ((UINT8 *) (MicrocodeEntryPoint)
|
|
||||||
+ DataSize + sizeof (CPU_MICROCODE_HEADER));
|
|
||||||
ExtendedTableCount = ExtendedTableHeader->ExtendedSignatureCount;
|
|
||||||
ExtendedTable = (CPU_MICROCODE_EXTENDED_TABLE *) (ExtendedTableHeader + 1);
|
|
||||||
|
|
||||||
for (Index = 0; Index < ExtendedTableCount; Index ++) {
|
|
||||||
//
|
|
||||||
// Avoid access content beyond MicrocodeEnd
|
|
||||||
//
|
|
||||||
if ((UINTN) ExtendedTable > MicrocodeEnd - sizeof (CPU_MICROCODE_EXTENDED_TABLE)) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Check the 'ProcessorSignature' and 'ProcessorFlag' of the Extended
|
|
||||||
// Signature Table entry with the CPUID and PlatformID of the processors
|
|
||||||
// within system to decide if it will be copied into memory
|
|
||||||
//
|
|
||||||
NeedLoad = IsMicrocodePatchNeedLoad (
|
|
||||||
CpuMpData,
|
|
||||||
ExtendedTable->ProcessorSignature.Uint32,
|
|
||||||
ExtendedTable->ProcessorFlag
|
|
||||||
);
|
|
||||||
if (NeedLoad) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
ExtendedTable ++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (NeedLoad) {
|
|
||||||
PatchCount++;
|
PatchCount++;
|
||||||
if (PatchCount > MaxPatchNumber) {
|
if (PatchCount > MaxPatchNumber) {
|
||||||
//
|
//
|
||||||
|
@ -581,7 +598,7 @@ LoadMicrocodePatch (
|
||||||
__FUNCTION__, PatchCount, TotalLoadSize
|
__FUNCTION__, PatchCount, TotalLoadSize
|
||||||
));
|
));
|
||||||
|
|
||||||
LoadMicrocodePatchWorker (CpuMpData, PatchInfoBuffer, PatchCount, TotalLoadSize);
|
ShadowMicrocodePatchWorker (CpuMpData, PatchInfoBuffer, PatchCount, TotalLoadSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
OnExit:
|
OnExit:
|
||||||
|
@ -590,3 +607,124 @@ OnExit:
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Shadow the required microcode patches data into memory according to FIT microcode entry.
|
||||||
|
|
||||||
|
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
||||||
|
|
||||||
|
@return EFI_SUCCESS Microcode patch is shadowed into memory.
|
||||||
|
@return EFI_UNSUPPORTED FIT based microcode shadowing is not supported.
|
||||||
|
@return EFI_OUT_OF_RESOURCES No enough memory resource.
|
||||||
|
@return EFI_NOT_FOUND There is something wrong in FIT microcode entry.
|
||||||
|
|
||||||
|
**/
|
||||||
|
EFI_STATUS
|
||||||
|
ShadowMicrocodePatchByFit (
|
||||||
|
IN OUT CPU_MP_DATA *CpuMpData
|
||||||
|
)
|
||||||
|
{
|
||||||
|
UINT64 FitPointer;
|
||||||
|
FIRMWARE_INTERFACE_TABLE_ENTRY *FitEntry;
|
||||||
|
UINT32 EntryNum;
|
||||||
|
UINT32 Index;
|
||||||
|
MICROCODE_PATCH_INFO *PatchInfoBuffer;
|
||||||
|
UINTN MaxPatchNumber;
|
||||||
|
CPU_MICROCODE_HEADER *MicrocodeEntryPoint;
|
||||||
|
UINTN PatchCount;
|
||||||
|
UINTN TotalSize;
|
||||||
|
UINTN TotalLoadSize;
|
||||||
|
|
||||||
|
if (!FeaturePcdGet (PcdCpuShadowMicrocodeByFit)) {
|
||||||
|
return EFI_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
FitPointer = *(UINT64 *) (UINTN) FIT_POINTER_ADDRESS;
|
||||||
|
if ((FitPointer == 0) ||
|
||||||
|
(FitPointer == 0xFFFFFFFFFFFFFFFF) ||
|
||||||
|
(FitPointer == 0xEEEEEEEEEEEEEEEE)) {
|
||||||
|
//
|
||||||
|
// No FIT table.
|
||||||
|
//
|
||||||
|
ASSERT (FALSE);
|
||||||
|
return EFI_NOT_FOUND;
|
||||||
|
}
|
||||||
|
FitEntry = (FIRMWARE_INTERFACE_TABLE_ENTRY *) (UINTN) FitPointer;
|
||||||
|
if ((FitEntry[0].Type != FIT_TYPE_00_HEADER) ||
|
||||||
|
(FitEntry[0].Address != FIT_TYPE_00_SIGNATURE)) {
|
||||||
|
//
|
||||||
|
// Invalid FIT table, treat it as no FIT table.
|
||||||
|
//
|
||||||
|
ASSERT (FALSE);
|
||||||
|
return EFI_NOT_FOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
EntryNum = *(UINT32 *)(&FitEntry[0].Size[0]) & 0xFFFFFF;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Calculate microcode entry number
|
||||||
|
//
|
||||||
|
MaxPatchNumber = 0;
|
||||||
|
for (Index = 0; Index < EntryNum; Index++) {
|
||||||
|
if (FitEntry[Index].Type == FIT_TYPE_01_MICROCODE) {
|
||||||
|
MaxPatchNumber++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (MaxPatchNumber == 0) {
|
||||||
|
return EFI_NOT_FOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
PatchInfoBuffer = AllocatePool (MaxPatchNumber * sizeof (MICROCODE_PATCH_INFO));
|
||||||
|
if (PatchInfoBuffer == NULL) {
|
||||||
|
return EFI_OUT_OF_RESOURCES;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Fill up microcode patch info buffer according to FIT table.
|
||||||
|
//
|
||||||
|
PatchCount = 0;
|
||||||
|
TotalLoadSize = 0;
|
||||||
|
for (Index = 0; Index < EntryNum; Index++) {
|
||||||
|
if (FitEntry[Index].Type == FIT_TYPE_01_MICROCODE) {
|
||||||
|
MicrocodeEntryPoint = (CPU_MICROCODE_HEADER *) (UINTN) FitEntry[Index].Address;
|
||||||
|
TotalSize = (MicrocodeEntryPoint->DataSize == 0) ? 2048 : MicrocodeEntryPoint->TotalSize;
|
||||||
|
if (IsMicrocodePatchNeedLoad (CpuMpData, MicrocodeEntryPoint)) {
|
||||||
|
PatchInfoBuffer[PatchCount].Address = (UINTN) MicrocodeEntryPoint;
|
||||||
|
PatchInfoBuffer[PatchCount].Size = TotalSize;
|
||||||
|
TotalLoadSize += TotalSize;
|
||||||
|
PatchCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (PatchCount != 0) {
|
||||||
|
DEBUG ((
|
||||||
|
DEBUG_INFO,
|
||||||
|
"%a: 0x%x microcode patches will be loaded into memory, with size 0x%x.\n",
|
||||||
|
__FUNCTION__, PatchCount, TotalLoadSize
|
||||||
|
));
|
||||||
|
|
||||||
|
ShadowMicrocodePatchWorker (CpuMpData, PatchInfoBuffer, PatchCount, TotalLoadSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
FreePool (PatchInfoBuffer);
|
||||||
|
return EFI_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Shadow the required microcode patches data into memory.
|
||||||
|
|
||||||
|
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
||||||
|
**/
|
||||||
|
VOID
|
||||||
|
ShadowMicrocodeUpdatePatch (
|
||||||
|
IN OUT CPU_MP_DATA *CpuMpData
|
||||||
|
)
|
||||||
|
{
|
||||||
|
EFI_STATUS Status;
|
||||||
|
|
||||||
|
Status = ShadowMicrocodePatchByFit (CpuMpData);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ShadowMicrocodePatchByPcd (CpuMpData);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
CPU MP Initialize Library common functions.
|
CPU MP Initialize Library common functions.
|
||||||
|
|
||||||
Copyright (c) 2016 - 2019, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2016 - 2020, Intel Corporation. All rights reserved.<BR>
|
||||||
SPDX-License-Identifier: BSD-2-Clause-Patent
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
|
|
||||||
**/
|
**/
|
||||||
|
@ -1744,7 +1744,7 @@ MpInitLibInitialize (
|
||||||
//
|
//
|
||||||
// Load required microcode patches data into memory
|
// Load required microcode patches data into memory
|
||||||
//
|
//
|
||||||
LoadMicrocodePatch (CpuMpData);
|
ShadowMicrocodeUpdatePatch (CpuMpData);
|
||||||
} else {
|
} else {
|
||||||
//
|
//
|
||||||
// APs have been wakeup before, just get the CPU Information
|
// APs have been wakeup before, just get the CPU Information
|
||||||
|
|
|
@ -29,6 +29,9 @@
|
||||||
#include <Library/MtrrLib.h>
|
#include <Library/MtrrLib.h>
|
||||||
#include <Library/HobLib.h>
|
#include <Library/HobLib.h>
|
||||||
|
|
||||||
|
#include <IndustryStandard/FirmwareInterfaceTable.h>
|
||||||
|
|
||||||
|
|
||||||
#define WAKEUP_AP_SIGNAL SIGNATURE_32 ('S', 'T', 'A', 'P')
|
#define WAKEUP_AP_SIGNAL SIGNATURE_32 ('S', 'T', 'A', 'P')
|
||||||
|
|
||||||
#define CPU_INIT_MP_LIB_HOB_GUID \
|
#define CPU_INIT_MP_LIB_HOB_GUID \
|
||||||
|
@ -587,12 +590,12 @@ MicrocodeDetect (
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Load the required microcode patches data into memory.
|
Shadow the required microcode patches data into memory.
|
||||||
|
|
||||||
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
@param[in, out] CpuMpData The pointer to CPU MP Data structure.
|
||||||
**/
|
**/
|
||||||
VOID
|
VOID
|
||||||
LoadMicrocodePatch (
|
ShadowMicrocodeUpdatePatch (
|
||||||
IN OUT CPU_MP_DATA *CpuMpData
|
IN OUT CPU_MP_DATA *CpuMpData
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
## @file
|
## @file
|
||||||
# MP Initialize Library instance for PEI driver.
|
# MP Initialize Library instance for PEI driver.
|
||||||
#
|
#
|
||||||
# Copyright (c) 2016 - 2017, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2016 - 2020, Intel Corporation. All rights reserved.<BR>
|
||||||
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
#
|
#
|
||||||
##
|
##
|
||||||
|
@ -60,6 +60,7 @@
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuMicrocodePatchRegionSize ## CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuMicrocodePatchRegionSize ## CONSUMES
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuApLoopMode ## CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuApLoopMode ## CONSUMES
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuApTargetCstate ## SOMETIMES_CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuApTargetCstate ## SOMETIMES_CONSUMES
|
||||||
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuShadowMicrocodeByFit ## CONSUMES
|
||||||
|
|
||||||
[Guids]
|
[Guids]
|
||||||
gEdkiiS3SmmInitDoneGuid
|
gEdkiiS3SmmInitDoneGuid
|
||||||
|
|
|
@ -139,6 +139,12 @@
|
||||||
# @Prompt Lock SMM Feature Control MSR.
|
# @Prompt Lock SMM Feature Control MSR.
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmFeatureControlMsrLock|TRUE|BOOLEAN|0x3213210B
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmFeatureControlMsrLock|TRUE|BOOLEAN|0x3213210B
|
||||||
|
|
||||||
|
## Indicates if FIT based microcode shadowing will be enabled.<BR><BR>
|
||||||
|
# TRUE - FIT base microcode shadowing will be enabled.<BR>
|
||||||
|
# FALSE - FIT base microcode shadowing will be disabled.<BR>
|
||||||
|
# @Prompt FIT based microcode shadowing.
|
||||||
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuShadowMicrocodeByFit|FALSE|BOOLEAN|0x3213210D
|
||||||
|
|
||||||
[PcdsFixedAtBuild]
|
[PcdsFixedAtBuild]
|
||||||
## List of exception vectors which need switching stack.
|
## List of exception vectors which need switching stack.
|
||||||
# This PCD will only take into effect if PcdCpuStackGuard is enabled.
|
# This PCD will only take into effect if PcdCpuStackGuard is enabled.
|
||||||
|
|
|
@ -100,6 +100,12 @@
|
||||||
"TRUE - locked.<BR>\n"
|
"TRUE - locked.<BR>\n"
|
||||||
"FALSE - unlocked.<BR>"
|
"FALSE - unlocked.<BR>"
|
||||||
|
|
||||||
|
#string STR_gUefiCpuPkgTokenSpaceGuid_PcdCpuShadowMicrocodeByFit_PROMPT #language en-US "FIT based microcode shadowing"
|
||||||
|
|
||||||
|
#string STR_gUefiCpuPkgTokenSpaceGuid_PcdCpuShadowMicrocodeByFit_HELP #language en-US "Indicates if FIT based microcode shadowing will be enabled.<BR><BR>\n"
|
||||||
|
"TRUE - FIT base microcode shadowing will be enabled.<BR>\n"
|
||||||
|
"FALSE - FIT base microcode shadowing will be disabled.<BR>"
|
||||||
|
|
||||||
#string STR_gUefiCpuPkgTokenSpaceGuid_PcdPeiTemporaryRamStackSize_PROMPT #language en-US "Stack size in the temporary RAM"
|
#string STR_gUefiCpuPkgTokenSpaceGuid_PcdPeiTemporaryRamStackSize_PROMPT #language en-US "Stack size in the temporary RAM"
|
||||||
|
|
||||||
#string STR_gUefiCpuPkgTokenSpaceGuid_PcdPeiTemporaryRamStackSize_HELP #language en-US "Specifies stack size in the temporary RAM. 0 means half of TemporaryRamSize."
|
#string STR_gUefiCpuPkgTokenSpaceGuid_PcdPeiTemporaryRamStackSize_HELP #language en-US "Specifies stack size in the temporary RAM. 0 means half of TemporaryRamSize."
|
||||||
|
|
Loading…
Reference in New Issue