2016-05-13 07:00:53 +02:00
|
|
|
/** @file
|
|
|
|
Sample to provide TempRamInitParams data.
|
|
|
|
|
2022-04-15 10:37:43 +02:00
|
|
|
Copyright (c) 2014 - 2022, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:04:06 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-05-13 07:00:53 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <Library/PcdLib.h>
|
|
|
|
#include <FspEas.h>
|
|
|
|
|
|
|
|
typedef struct {
|
2022-09-06 21:52:39 +02:00
|
|
|
EFI_PHYSICAL_ADDRESS MicrocodeRegionBase;
|
|
|
|
UINT64 MicrocodeRegionSize;
|
|
|
|
EFI_PHYSICAL_ADDRESS CodeRegionBase;
|
|
|
|
UINT64 CodeRegionSize;
|
2016-05-13 07:00:53 +02:00
|
|
|
} FSPT_CORE_UPD;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
FSP_UPD_HEADER FspUpdHeader;
|
2020-06-18 14:59:37 +02:00
|
|
|
//
|
2022-04-15 10:37:43 +02:00
|
|
|
// If FSP spec version < 2.2, remove FSPT_ARCH_UPD structure.
|
|
|
|
// Else If FSP spec version >= 2.2 and FSP spec version < 2.4, use FSPT_ARCH_UPD structure.
|
|
|
|
// Else, use FSPT_ARCH2_UPD structure.
|
2020-06-18 14:59:37 +02:00
|
|
|
//
|
2022-04-15 10:37:43 +02:00
|
|
|
FSPT_ARCH2_UPD FsptArchUpd;
|
2016-05-13 07:00:53 +02:00
|
|
|
FSPT_CORE_UPD FsptCoreUpd;
|
|
|
|
} FSPT_UPD_CORE_DATA;
|
|
|
|
|
|
|
|
GLOBAL_REMOVE_IF_UNREFERENCED CONST FSPT_UPD_CORE_DATA FsptUpdDataPtr = {
|
|
|
|
{
|
|
|
|
0x4450555F54505346,
|
2020-06-18 14:59:37 +02:00
|
|
|
//
|
|
|
|
// UPD header revision must be equal or greater than 2 when the structure is compliant with FSP spec 2.2.
|
|
|
|
//
|
|
|
|
0x02,
|
2016-05-13 07:00:53 +02:00
|
|
|
{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
|
|
|
|
},
|
2020-06-18 14:59:37 +02:00
|
|
|
//
|
2022-04-15 10:37:43 +02:00
|
|
|
// If FSP spec version < 2.2, remove FSPT_ARCH_UPD structure.
|
|
|
|
// Else If FSP spec version >= 2.2 and FSP spec version < 2.4, use FSPT_ARCH_UPD structure.
|
|
|
|
// Else, use FSPT_ARCH2_UPD structure.
|
2020-06-18 14:59:37 +02:00
|
|
|
//
|
|
|
|
{
|
2022-04-15 10:37:43 +02:00
|
|
|
0x02,
|
2020-06-18 14:59:37 +02:00
|
|
|
{
|
|
|
|
0x00, 0x00, 0x00
|
|
|
|
},
|
|
|
|
0x00000020,
|
|
|
|
0x00000000,
|
|
|
|
{
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
2022-04-15 10:37:43 +02:00
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00
|
2020-06-18 14:59:37 +02:00
|
|
|
}
|
|
|
|
},
|
2016-05-13 07:00:53 +02:00
|
|
|
{
|
2021-04-15 08:48:47 +02:00
|
|
|
FixedPcdGet32 (PcdCpuMicrocodePatchAddress),
|
|
|
|
FixedPcdGet32 (PcdCpuMicrocodePatchRegionSize),
|
2016-05-13 07:00:53 +02:00
|
|
|
FixedPcdGet32 (PcdFlashCodeCacheAddress),
|
|
|
|
FixedPcdGet32 (PcdFlashCodeCacheSize),
|
|
|
|
}
|
|
|
|
};
|