driver/intel/fsp2_0: Add support to store MRC cache using MRC version
This patch uses the "generic" variable name as "version" while storing the MRC cache data instead referring to the FSP-M version or MRC version. Hence, updated all the instances of `fsp_version/fspm_version` with `version`. Also introduces the new option to the MRC cache version that allows SoC users to store the MRC cache version based on the supported EDK2 version. Intel FSP built with EDK2 version 202302 onwards has support to retrieve the MRC version by directly parsing the binary. Additionally, added the helper function `fsp_mrc_version()` and corresponding header file to read the MRC version from the FSP binary. BUG=b:261689642 TEST=Able to build and boot google/rex and google/omnigul. Signed-off-by: Subrata Banik <subratabanik@google.com> Change-Id: Ia8af53aed674ad4a3b426264706264df91d9c6b0 Reviewed-on: https://review.coreboot.org/c/coreboot/+/75920 Reviewed-by: Tarun Tuli <taruntuli@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Ronak Kanabar <ronak.kanabar@intel.com> Reviewed-by: Nico Huber <nico.h@gmx.de> Reviewed-by: Kapil Porwal <kapilporwal@google.com>
This commit is contained in:
parent
ea13dc3562
commit
79274e01a3
4 changed files with 63 additions and 16 deletions
|
@ -27,6 +27,10 @@
|
|||
#include <Base.h>
|
||||
#include <FspmUpd.h>
|
||||
#include <FspsUpd.h>
|
||||
#if CONFIG(MRC_CACHE_USING_MRC_VERSION)
|
||||
#define BUILD_TIME_STAMP_SIZE 12
|
||||
#include <FspProducerDataHeader.h>
|
||||
#endif
|
||||
#if CONFIG(DISPLAY_FSP_VERSION_INFO)
|
||||
#include <FirmwareVersionInfoHob.h>
|
||||
#elif CONFIG(DISPLAY_FSP_VERSION_INFO_2)
|
||||
|
|
|
@ -30,7 +30,7 @@
|
|||
|
||||
static uint8_t temp_ram[CONFIG_FSP_TEMP_RAM_SIZE] __aligned(sizeof(uint64_t));
|
||||
|
||||
static void do_fsp_post_memory_init(bool s3wake, uint32_t fsp_version)
|
||||
static void do_fsp_post_memory_init(bool s3wake, uint32_t version)
|
||||
{
|
||||
struct range_entry fsp_mem;
|
||||
uint32_t *fsp_version_cbmem;
|
||||
|
@ -59,17 +59,17 @@ static void do_fsp_post_memory_init(bool s3wake, uint32_t fsp_version)
|
|||
/* ramstage uses the FSP-M version when updating the MRC cache */
|
||||
if (CONFIG(CACHE_MRC_SETTINGS) && !s3wake) {
|
||||
fsp_version_cbmem = cbmem_add(CBMEM_ID_FSPM_VERSION,
|
||||
sizeof(fsp_version));
|
||||
sizeof(version));
|
||||
if (!fsp_version_cbmem)
|
||||
printk(BIOS_ERR, "Failed to add FSP-M version to cbmem.\n");
|
||||
*fsp_version_cbmem = fsp_version;
|
||||
*fsp_version_cbmem = version;
|
||||
}
|
||||
|
||||
/* Create romstage handof information */
|
||||
romstage_handoff_init(s3wake);
|
||||
}
|
||||
|
||||
static void fsp_fill_mrc_cache(FSPM_ARCH_UPD *arch_upd, uint32_t fsp_version)
|
||||
static void fsp_fill_mrc_cache(FSPM_ARCH_UPD *arch_upd, uint32_t version)
|
||||
{
|
||||
void *data;
|
||||
size_t mrc_size;
|
||||
|
@ -82,7 +82,7 @@ static void fsp_fill_mrc_cache(FSPM_ARCH_UPD *arch_upd, uint32_t fsp_version)
|
|||
/* Assume boot device is memory mapped. */
|
||||
assert(CONFIG(BOOT_DEVICE_MEMORY_MAPPED));
|
||||
|
||||
data = mrc_cache_current_mmap_leak(MRC_TRAINING_DATA, fsp_version,
|
||||
data = mrc_cache_current_mmap_leak(MRC_TRAINING_DATA, version,
|
||||
&mrc_size);
|
||||
if (data == NULL)
|
||||
return;
|
||||
|
@ -134,7 +134,7 @@ static enum cb_err setup_fsp_stack_frame(FSPM_ARCH_UPD *arch_upd,
|
|||
}
|
||||
|
||||
static enum cb_err fsp_fill_common_arch_params(FSPM_ARCH_UPD *arch_upd,
|
||||
bool s3wake, uint32_t fsp_version,
|
||||
bool s3wake, uint32_t version,
|
||||
const struct memranges *memmap)
|
||||
{
|
||||
/*
|
||||
|
@ -152,7 +152,7 @@ static enum cb_err fsp_fill_common_arch_params(FSPM_ARCH_UPD *arch_upd,
|
|||
return CB_ERR;
|
||||
}
|
||||
|
||||
fsp_fill_mrc_cache(arch_upd, fsp_version);
|
||||
fsp_fill_mrc_cache(arch_upd, version);
|
||||
|
||||
/* Configure bootmode */
|
||||
if (s3wake) {
|
||||
|
@ -210,19 +210,50 @@ struct fspm_context {
|
|||
struct memranges memmap;
|
||||
};
|
||||
|
||||
/*
|
||||
* Helper function to read MRC version
|
||||
*
|
||||
* There are multiple ways to read the MRC version using
|
||||
* Intel FSP. Currently the only supported method to get the
|
||||
* MRC version is by reading the FSP_PRODUCDER_DATA_TABLES
|
||||
* from the FSP-M binary (by parsing the FSP header).
|
||||
*/
|
||||
static uint32_t fsp_mrc_version(void)
|
||||
{
|
||||
uint32_t ver = 0;
|
||||
#if CONFIG(MRC_CACHE_USING_MRC_VERSION)
|
||||
size_t fspm_blob_size;
|
||||
void *fspm_blob_file = cbfs_map(CONFIG_FSP_M_CBFS, &fspm_blob_size);
|
||||
if (!fspm_blob_file)
|
||||
return 0;
|
||||
|
||||
FSP_PRODUCER_DATA_TABLES *ft = fspm_blob_file + FSP_HDR_OFFSET;
|
||||
FSP_PRODUCER_DATA_TYPE2 *table2 = &ft->FspProduceDataType2;
|
||||
size_t mrc_version_size = sizeof(table2->MrcVersion);
|
||||
for (size_t i = 0; i < mrc_version_size; i++) {
|
||||
ver |= (table2->MrcVersion[i] << ((mrc_version_size - 1) - i) * 8);
|
||||
}
|
||||
cbfs_unmap(fspm_blob_file);
|
||||
#endif
|
||||
return ver;
|
||||
}
|
||||
|
||||
static void do_fsp_memory_init(const struct fspm_context *context, bool s3wake)
|
||||
{
|
||||
uint32_t status;
|
||||
fsp_memory_init_fn fsp_raminit;
|
||||
FSPM_UPD fspm_upd, *upd;
|
||||
FSPM_ARCH_UPD *arch_upd;
|
||||
uint32_t fsp_version;
|
||||
uint32_t version;
|
||||
const struct fsp_header *hdr = &context->header;
|
||||
const struct memranges *memmap = &context->memmap;
|
||||
|
||||
post_code(POST_MEM_PREINIT_PREP_START);
|
||||
|
||||
fsp_version = fsp_memory_settings_version(hdr);
|
||||
if (CONFIG(MRC_CACHE_USING_MRC_VERSION))
|
||||
version = fsp_mrc_version();
|
||||
else
|
||||
version = fsp_memory_settings_version(hdr);
|
||||
|
||||
upd = (FSPM_UPD *)(uintptr_t)(hdr->cfg_region_offset + hdr->image_base);
|
||||
|
||||
|
@ -254,7 +285,7 @@ static void do_fsp_memory_init(const struct fspm_context *context, bool s3wake)
|
|||
arch_upd->BootLoaderTolumSize = cbmem_overhead_size();
|
||||
|
||||
/* Fill common settings on behalf of chipset. */
|
||||
if (fsp_fill_common_arch_params(arch_upd, s3wake, fsp_version,
|
||||
if (fsp_fill_common_arch_params(arch_upd, s3wake, version,
|
||||
memmap) != CB_SUCCESS)
|
||||
die_with_post_code(POST_INVALID_VENDOR_BINARY,
|
||||
"FSPM_ARCH_UPD not found!\n");
|
||||
|
@ -266,7 +297,7 @@ static void do_fsp_memory_init(const struct fspm_context *context, bool s3wake)
|
|||
#endif
|
||||
|
||||
/* Give SoC and mainboard a chance to update the UPD */
|
||||
platform_fsp_memory_init_params_cb(&fspm_upd, fsp_version);
|
||||
platform_fsp_memory_init_params_cb(&fspm_upd, version);
|
||||
|
||||
/*
|
||||
* For S3 resume case, if valid mrc cache data is not found or
|
||||
|
@ -309,7 +340,7 @@ static void do_fsp_memory_init(const struct fspm_context *context, bool s3wake)
|
|||
"FspMemoryInit returned with error 0x%08x!\n", status);
|
||||
}
|
||||
|
||||
do_fsp_post_memory_init(s3wake, fsp_version);
|
||||
do_fsp_post_memory_init(s3wake, version);
|
||||
|
||||
/*
|
||||
* fsp_debug_after_memory_init() checks whether the end of the tolum
|
||||
|
|
|
@ -11,13 +11,13 @@ static void save_mrc_data(void *unused)
|
|||
{
|
||||
size_t mrc_data_size;
|
||||
const void *mrc_data;
|
||||
uint32_t *fspm_version;
|
||||
uint32_t *version;
|
||||
|
||||
if (acpi_is_wakeup_s3())
|
||||
return;
|
||||
|
||||
fspm_version = cbmem_find(CBMEM_ID_FSPM_VERSION);
|
||||
if (!fspm_version) {
|
||||
version = cbmem_find(CBMEM_ID_FSPM_VERSION);
|
||||
if (!version) {
|
||||
printk(BIOS_ERR, "Failed to read FSP-M version from cbmem.\n");
|
||||
return;
|
||||
}
|
||||
|
@ -34,7 +34,7 @@ static void save_mrc_data(void *unused)
|
|||
* code which saves the data to flash doesn't write if the latest
|
||||
* training data matches this one.
|
||||
*/
|
||||
if (mrc_cache_stash_data(MRC_TRAINING_DATA, *fspm_version, mrc_data,
|
||||
if (mrc_cache_stash_data(MRC_TRAINING_DATA, *version, mrc_data,
|
||||
mrc_data_size) < 0)
|
||||
printk(BIOS_ERR, "Failed to stash MRC data\n");
|
||||
}
|
||||
|
|
|
@ -52,4 +52,16 @@ config MRC_SAVE_HASH_IN_TPM
|
|||
Store a hash of the MRC_CACHE training data in a TPM NVRAM
|
||||
space to ensure that it cannot be tampered with.
|
||||
|
||||
config MRC_CACHE_USING_MRC_VERSION
|
||||
bool
|
||||
default y if UDK_VERSION >= UDK_202302_VERSION
|
||||
default n
|
||||
help
|
||||
Use the MRC version info from FSP extended header to store the MRC cache data.
|
||||
This method relies on the FSP_PRODUCER_DATA_TABLES belongs to the
|
||||
`FspProducerDataHeader.h`file to get the MRC version.
|
||||
|
||||
Intel FSP built with EDK2 version 202302 onwards has support to retrieve the
|
||||
MRC version by directly parsing the binary.
|
||||
|
||||
endif # CACHE_MRC_SETTINGS
|
||||
|
|
Loading…
Reference in a new issue