soc/intel/jasperlake: Allow mainboard to override chip configuration

Add a weak override function to allow mainboard to override chip
configuration like GPIO PM.

BUG=None
TEST=Build and boot waddledee to OS. Ensure that the suspend/resume
sequence works fine.

Change-Id: I40fa655b0324dc444182b988f0089587e3877a47
Signed-off-by: Karthikeyan Ramasubramanian <kramasub@google.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/45856
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
Karthikeyan Ramasubramanian 2020-09-29 22:01:47 -06:00 committed by Patrick Georgi
parent 463e44bedb
commit 5acea15d63
2 changed files with 9 additions and 0 deletions

View file

@ -78,6 +78,11 @@ static void parse_devicetree(FSP_S_CONFIG *params)
sizeof(config->SerialIoUartMode)); sizeof(config->SerialIoUartMode));
} }
__weak void mainboard_update_soc_chip_config(struct soc_intel_jasperlake_config *config)
{
/* Override settings per board. */
}
/* UPD parameters to be initialized before SiliconInit */ /* UPD parameters to be initialized before SiliconInit */
void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd) void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
{ {
@ -86,6 +91,9 @@ void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
FSP_S_CONFIG *params = &supd->FspsConfig; FSP_S_CONFIG *params = &supd->FspsConfig;
struct soc_intel_jasperlake_config *config = config_of_soc(); struct soc_intel_jasperlake_config *config = config_of_soc();
/* Allow mainboard to override any chip config */
mainboard_update_soc_chip_config(config);
/* Parse device tree and fill in FSP UPDs */ /* Parse device tree and fill in FSP UPDs */
parse_devicetree(params); parse_devicetree(params);

View file

@ -9,6 +9,7 @@
#include <soc/soc_chip.h> #include <soc/soc_chip.h>
void mainboard_silicon_init_params(FSP_S_CONFIG *params); void mainboard_silicon_init_params(FSP_S_CONFIG *params);
void mainboard_update_soc_chip_config(struct soc_intel_jasperlake_config *config);
void soc_init_pre_device(void *chip_info); void soc_init_pre_device(void *chip_info);
#endif #endif