diff options
Diffstat (limited to 'src/soc/intel/common/block')
-rw-r--r-- | src/soc/intel/common/block/include/intelblocks/smihandler.h | 3 | ||||
-rw-r--r-- | src/soc/intel/common/block/smm/smihandler.c | 9 |
2 files changed, 12 insertions, 0 deletions
diff --git a/src/soc/intel/common/block/include/intelblocks/smihandler.h b/src/soc/intel/common/block/include/intelblocks/smihandler.h index df2d17c9e2..197268b29e 100644 --- a/src/soc/intel/common/block/include/intelblocks/smihandler.h +++ b/src/soc/intel/common/block/include/intelblocks/smihandler.h @@ -148,6 +148,9 @@ struct global_nvs_t *smm_get_gnvs(void); /* SoC overrides. */ +/* Specific SOC SMI handler during ramstage finalize phase */ +void smihandler_soc_at_finalize(void); + /* * This function returns a 1 or 0 depending on whether disable_busmaster * needs to be done for the specified device on S5 entry diff --git a/src/soc/intel/common/block/smm/smihandler.c b/src/soc/intel/common/block/smm/smihandler.c index 8a877c3570..81ff3ebec8 100644 --- a/src/soc/intel/common/block/smm/smihandler.c +++ b/src/soc/intel/common/block/smm/smihandler.c @@ -38,6 +38,12 @@ static struct global_nvs_t *gnvs; /* SoC overrides. */ +/* Specific SOC SMI handler during ramstage finalize phase */ +__attribute__((weak)) void smihandler_soc_at_finalize(void) +{ + return; +} + __attribute__((weak)) int smihandler_soc_disable_busmaster(device_t dev) { return 1; @@ -278,6 +284,9 @@ static void finalize(void) if (IS_ENABLED(CONFIG_SPI_FLASH_SMM)) /* Re-init SPI driver to handle locked BAR */ fast_spi_init(); + + /* Specific SOC SMI handler during ramstage finalize phase */ + smihandler_soc_at_finalize(); } void smihandler_southbridge_apmc( |