drivers/intel/fsp2_0: Refactor MultiPhaseSiInit API calling method
FspMultiPhaseSiInit API was introduced with FSP 2.2 specification onwards. EnableMultiPhaseSiliconInit is an arch UPD also introduced as part of FSP 2.2 specification to allow calling FspMultiPhaseSiInit API. However, some platforms adhere to the FSP specification but don't have arch UPD structure, for example : JSL, TGL and Xeon-SP. Out of these platforms, TGL supports calling of FspMultiPhaseSiInit API and considered EnableMultiPhaseSiliconInit as a platform-specific UPD rather than an arch UPD to allow calling into FspMultiPhaseSiInit API. It is important to ensure that the UPD setting and the callback for MultiPhaseInit are kept in sync, else it could result in broken behavior e.g. a hang is seen in FSP if EnableMultiPhaseSiliconInit UPD is set to 1 but the FspMultiPhaseSiInit API call is skipped. This patch provides an option for users to choose to bypass calling into MultiPhaseSiInit API and ensures the EnableMultiPhaseSiliconInit UPD is set to its default state as `disable` so that FSP-S don't consider MultiPhaseSiInit API is a mandatory entry point prior to calling other FSP API entry points. List of changes: 1. Add `FSPS_HAS_ARCH_UPD` Kconfig for SoC to select if `FSPS_ARCH_UPD` structure is part of `FSPS_UPD` structure. 2. Drop `soc_fsp_multi_phase_init_is_enable()` from JSL and Xeon-SP SoCs, a SoC override to callout that SoC doesn't support calling MultiPhase Si Init is no longer required. 3. Add `FSPS_USE_MULTI_PHASE_INIT` Kconfig for SoC to specify if SoC users want to enable `EnableMultiPhaseSiliconInit` arch UPD (using `fsp_fill_common_arch_params()`) and execute FspMultiPhaseSiInit() API. 4. Presently selects `FSPS_USE_MULTI_PHASE_INIT` from IA TCSS common code. 5. Add `fsp_is_multi_phase_init_enabled()` that check applicability of MultiPhase Si Init prior calling FspMultiPhaseSiInit() API to honor SoC users' decision. 6. Drop `arch_silicon_init_params()` from SoC as FSP driver (FSP 2.2) would check the applicability of MultiPhase Si Init prior calling FspMultiPhaseSiInit() API. Additionally, selects FSPS_HAS_ARCH_UPD for Alder Lake as Alder Lake FSPS_UPD structure has `FSPS_ARCH_UPD` structure and drops `arch_silicon_init_params()` from SoC `platform_fsp_silicon_init_params_cb()`. Skip EnableMultiPhaseSiliconInit hardcoding for Tiger Lake and uses the fsp_is_multi_phase_init_enabled() function to override EnableMultiPhaseSiliconInit UPD prior calling MultiPhaseSiInit FSP API. TEST=EnableMultiPhaseSiliconInit UPD is getting set or reset based on SoC user selects FSPS_USE_MULTI_PHASE_INIT Kconfig. Change-Id: I019fa8364605f5061d56e2d80b20e1a91857c423 Signed-off-by: Subrata Banik <subrata.banik@intel.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/56382 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
8407c3464c
commit
298b35923d
9 changed files with 40 additions and 30 deletions
|
@ -274,4 +274,20 @@ config SOC_INTEL_COMMON_FSP_RESET
|
||||||
Common code block to handle platform reset request raised by FSP. The FSP
|
Common code block to handle platform reset request raised by FSP. The FSP
|
||||||
will use the FSP EAS v2.0 section 12.2.2 (OEM Status Code) to indicate that
|
will use the FSP EAS v2.0 section 12.2.2 (OEM Status Code) to indicate that
|
||||||
a reset is required.
|
a reset is required.
|
||||||
|
|
||||||
|
config FSPS_HAS_ARCH_UPD
|
||||||
|
bool
|
||||||
|
help
|
||||||
|
SoC users must select this Kconfig if the `FSPS_UPD` header has architecture
|
||||||
|
UPD structure as `FSPS_ARCH_UPD`. Typically, platform with FSP 2.2 specification
|
||||||
|
onwards has support for `FSPS_ARCH_UPD` section as part of `FSPS_UPD` structure.
|
||||||
|
But there are some exceptions as in TGL, JSL, XEON_SP FSP header doesn't have
|
||||||
|
support for FSPS_ARCH_UPD.
|
||||||
|
|
||||||
|
config FSPS_USE_MULTI_PHASE_INIT
|
||||||
|
bool
|
||||||
|
help
|
||||||
|
SoC users to select this Kconfig to set EnableMultiPhaseSiliconInit to enable and
|
||||||
|
execute FspMultiPhaseSiInit() API.
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -47,8 +47,8 @@ void platform_fsp_memory_init_params_cb(FSPM_UPD *mupd, uint32_t version);
|
||||||
void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd);
|
void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd);
|
||||||
/* Callbacks for SoC/Mainboard specific overrides */
|
/* Callbacks for SoC/Mainboard specific overrides */
|
||||||
void platform_fsp_multi_phase_init_cb(uint32_t phase_index);
|
void platform_fsp_multi_phase_init_cb(uint32_t phase_index);
|
||||||
/* Check if SoC sets EnableMultiPhaseSiliconInit UPD */
|
/* Check if MultiPhase Si Init is enabled */
|
||||||
int soc_fsp_multi_phase_init_is_enable(void);
|
bool fsp_is_multi_phase_init_enabled(void);
|
||||||
/*
|
/*
|
||||||
* The following functions are used when FSP_PLATFORM_MEMORY_SETTINGS_VERSION
|
* The following functions are used when FSP_PLATFORM_MEMORY_SETTINGS_VERSION
|
||||||
* is employed allowing the mainboard and SoC to supply their own version
|
* is employed allowing the mainboard and SoC to supply their own version
|
||||||
|
|
|
@ -29,11 +29,6 @@ void __weak platform_fsp_multi_phase_init_cb(uint32_t phase_index)
|
||||||
/* Leave for the SoC/Mainboard to implement if necessary. */
|
/* Leave for the SoC/Mainboard to implement if necessary. */
|
||||||
}
|
}
|
||||||
|
|
||||||
int __weak soc_fsp_multi_phase_init_is_enable(void)
|
|
||||||
{
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* FSP Specification < 2.2 has only 1 stage like FspSiliconInit. FSP specification >= 2.2
|
/* FSP Specification < 2.2 has only 1 stage like FspSiliconInit. FSP specification >= 2.2
|
||||||
* has multiple stages as below.
|
* has multiple stages as below.
|
||||||
*/
|
*/
|
||||||
|
@ -77,6 +72,20 @@ static void fsps_return_value_handler(enum fsp_silicon_init_phases phases, uint3
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool fsp_is_multi_phase_init_enabled(void)
|
||||||
|
{
|
||||||
|
return CONFIG(FSPS_USE_MULTI_PHASE_INIT) &&
|
||||||
|
(fsps_hdr.multi_phase_si_init_entry_offset != 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fsp_fill_common_arch_params(FSPS_UPD *supd)
|
||||||
|
{
|
||||||
|
#if CONFIG(FSPS_HAS_ARCH_UPD)
|
||||||
|
FSPS_ARCH_UPD *s_arch_cfg = &supd->FspsArchUpd;
|
||||||
|
s_arch_cfg->EnableMultiPhaseSiliconInit = fsp_is_multi_phase_init_enabled();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
static void do_silicon_init(struct fsp_header *hdr)
|
static void do_silicon_init(struct fsp_header *hdr)
|
||||||
{
|
{
|
||||||
FSPS_UPD *upd, *supd;
|
FSPS_UPD *upd, *supd;
|
||||||
|
@ -106,6 +115,9 @@ static void do_silicon_init(struct fsp_header *hdr)
|
||||||
|
|
||||||
memcpy(upd, supd, hdr->cfg_region_size);
|
memcpy(upd, supd, hdr->cfg_region_size);
|
||||||
|
|
||||||
|
/* Fill common settings on behalf of chipset. */
|
||||||
|
if (CONFIG(FSPS_HAS_ARCH_UPD))
|
||||||
|
fsp_fill_common_arch_params(upd);
|
||||||
/* Give SoC/mainboard a chance to populate entries */
|
/* Give SoC/mainboard a chance to populate entries */
|
||||||
platform_fsp_silicon_init_params_cb(upd);
|
platform_fsp_silicon_init_params_cb(upd);
|
||||||
|
|
||||||
|
@ -145,7 +157,7 @@ static void do_silicon_init(struct fsp_header *hdr)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* Check if SoC user would like to call Multi Phase Init */
|
/* Check if SoC user would like to call Multi Phase Init */
|
||||||
if (!soc_fsp_multi_phase_init_is_enable())
|
if (!fsp_is_multi_phase_init_enabled())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* Call MultiPhaseSiInit */
|
/* Call MultiPhaseSiInit */
|
||||||
|
|
|
@ -24,6 +24,7 @@ config CPU_SPECIFIC_OPTIONS
|
||||||
select FAST_SPI_SUPPORTS_EXT_BIOS_WINDOW
|
select FAST_SPI_SUPPORTS_EXT_BIOS_WINDOW
|
||||||
select FSP_M_XIP
|
select FSP_M_XIP
|
||||||
select FSP_STATUS_GLOBAL_RESET_REQUIRED_3
|
select FSP_STATUS_GLOBAL_RESET_REQUIRED_3
|
||||||
|
select FSPS_HAS_ARCH_UPD
|
||||||
select GENERIC_GPIO_LIB
|
select GENERIC_GPIO_LIB
|
||||||
select HAVE_FSP_GOP
|
select HAVE_FSP_GOP
|
||||||
select INTEL_DESCRIPTOR_MODE_CAPABLE
|
select INTEL_DESCRIPTOR_MODE_CAPABLE
|
||||||
|
|
|
@ -672,12 +672,6 @@ static void fill_fsps_fivr_params(FSP_S_CONFIG *s_cfg,
|
||||||
config->ext_fivr_settings.vnn_icc_max_ma;
|
config->ext_fivr_settings.vnn_icc_max_ma;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void arch_silicon_init_params(FSPS_ARCH_UPD *s_arch_cfg)
|
|
||||||
{
|
|
||||||
/* EnableMultiPhaseSiliconInit for running MultiPhaseSiInit */
|
|
||||||
s_arch_cfg->EnableMultiPhaseSiliconInit = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void soc_silicon_init_params(FSP_S_CONFIG *s_cfg,
|
static void soc_silicon_init_params(FSP_S_CONFIG *s_cfg,
|
||||||
struct soc_intel_alderlake_config *config)
|
struct soc_intel_alderlake_config *config)
|
||||||
{
|
{
|
||||||
|
@ -718,10 +712,8 @@ void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
|
||||||
{
|
{
|
||||||
struct soc_intel_alderlake_config *config;
|
struct soc_intel_alderlake_config *config;
|
||||||
FSP_S_CONFIG *s_cfg = &supd->FspsConfig;
|
FSP_S_CONFIG *s_cfg = &supd->FspsConfig;
|
||||||
FSPS_ARCH_UPD *s_arch_cfg = &supd->FspsArchUpd;
|
|
||||||
|
|
||||||
config = config_of_soc();
|
config = config_of_soc();
|
||||||
arch_silicon_init_params(s_arch_cfg);
|
|
||||||
soc_silicon_init_params(s_cfg, config);
|
soc_silicon_init_params(s_cfg, config);
|
||||||
mainboard_silicon_init_params(s_cfg);
|
mainboard_silicon_init_params(s_cfg);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
config SOC_INTEL_COMMON_BLOCK_TCSS
|
config SOC_INTEL_COMMON_BLOCK_TCSS
|
||||||
def_bool n
|
def_bool n
|
||||||
|
select FSPS_USE_MULTI_PHASE_INIT
|
||||||
help
|
help
|
||||||
Sets up USB2/3 port mapping in TCSS MUX and sets MUX to disconnect state
|
Sets up USB2/3 port mapping in TCSS MUX and sets MUX to disconnect state
|
||||||
|
|
||||||
|
|
|
@ -204,12 +204,6 @@ void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
|
||||||
mainboard_silicon_init_params(params);
|
mainboard_silicon_init_params(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Disable Multiphase Si init */
|
|
||||||
int soc_fsp_multi_phase_init_is_enable(void)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Mainboard GPIO Configuration */
|
/* Mainboard GPIO Configuration */
|
||||||
__weak void mainboard_silicon_init_params(FSP_S_CONFIG *params)
|
__weak void mainboard_silicon_init_params(FSP_S_CONFIG *params)
|
||||||
{
|
{
|
||||||
|
|
|
@ -565,8 +565,8 @@ void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
|
||||||
config->PchPmSlpS3MinAssert, config->PchPmSlpAMinAssert,
|
config->PchPmSlpS3MinAssert, config->PchPmSlpAMinAssert,
|
||||||
config->PchPmPwrCycDur);
|
config->PchPmPwrCycDur);
|
||||||
|
|
||||||
/* EnableMultiPhaseSiliconInit for running MultiPhaseSiInit */
|
/* Override EnableMultiPhaseSiliconInit prior calling MultiPhaseSiInit */
|
||||||
params->EnableMultiPhaseSiliconInit = 1;
|
params->EnableMultiPhaseSiliconInit = fsp_is_multi_phase_init_enabled();
|
||||||
|
|
||||||
/* Disable C1 C-state Demotion */
|
/* Disable C1 C-state Demotion */
|
||||||
params->C1StateAutoDemotion = 0;
|
params->C1StateAutoDemotion = 0;
|
||||||
|
|
|
@ -1,13 +1,7 @@
|
||||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
|
|
||||||
#include <fsp/api.h>
|
|
||||||
#include <smbios.h>
|
#include <smbios.h>
|
||||||
|
|
||||||
int soc_fsp_multi_phase_init_is_enable(void)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned int smbios_cpu_get_max_speed_mhz(void)
|
unsigned int smbios_cpu_get_max_speed_mhz(void)
|
||||||
{
|
{
|
||||||
return 3900;
|
return 3900;
|
||||||
|
|
Loading…
Reference in a new issue