fsp2_0: implement stage cache for silicon init
Stage cache will save ~20ms on S3 resume for apollolake platforms. Implementing the cache in ramstage to save silicon init and reload it on resume. This patch adds passing S3 status to silicon init in order to verify that the wake is from S3 and not for some other reason. This patch also includes changes needed for quark and skylake platforms that require fsp 2.0. BUG=chrome-os-partner:56941 BRANCH=none TEST=built for reef and tested boot and S3 resume path saving 20ms Change-Id: I99dc93c1d7a7d5cf8d8de1aa253a326ec67f05f6 Signed-off-by: Brandon Breitenstein <brandon.breitenstein@intel.com> Reviewed-on: https://review.coreboot.org/17460 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
5c325491ca
commit
c6ec8dd1cb
5 changed files with 34 additions and 5 deletions
|
@ -38,7 +38,7 @@ enum fsp_notify_phase {
|
||||||
|
|
||||||
/* Main FSP stages */
|
/* Main FSP stages */
|
||||||
void fsp_memory_init(bool s3wake);
|
void fsp_memory_init(bool s3wake);
|
||||||
void fsp_silicon_init(void);
|
void fsp_silicon_init(bool s3wake);
|
||||||
|
|
||||||
/* Callbacks for updating stage-specific parameters */
|
/* Callbacks for updating stage-specific parameters */
|
||||||
void platform_fsp_memory_init_params_cb(FSPM_UPD *mupd);
|
void platform_fsp_memory_init_params_cb(FSPM_UPD *mupd);
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include <fsp/api.h>
|
#include <fsp/api.h>
|
||||||
#include <fsp/util.h>
|
#include <fsp/util.h>
|
||||||
#include <program_loading.h>
|
#include <program_loading.h>
|
||||||
|
#include <stage_cache.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <timestamp.h>
|
#include <timestamp.h>
|
||||||
|
|
||||||
|
@ -61,7 +62,7 @@ static void do_silicon_init(struct fsp_header *hdr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void fsp_silicon_init(void)
|
void fsp_silicon_init(bool s3wake)
|
||||||
{
|
{
|
||||||
struct fsp_header *hdr = &fsps_hdr;
|
struct fsp_header *hdr = &fsps_hdr;
|
||||||
struct cbfsf file_desc;
|
struct cbfsf file_desc;
|
||||||
|
@ -69,6 +70,17 @@ void fsp_silicon_init(void)
|
||||||
const char *name = CONFIG_FSP_S_CBFS;
|
const char *name = CONFIG_FSP_S_CBFS;
|
||||||
void *dest;
|
void *dest;
|
||||||
size_t size;
|
size_t size;
|
||||||
|
struct prog fsps = PROG_INIT(PROG_REFCODE, name);
|
||||||
|
|
||||||
|
if (s3wake && !IS_ENABLED(CONFIG_NO_STAGE_CACHE)) {
|
||||||
|
printk(BIOS_DEBUG, "Loading FSPS from stage_cache\n");
|
||||||
|
stage_cache_load_stage(STAGE_REFCODE, &fsps);
|
||||||
|
if (fsp_validate_component(hdr, prog_rdev(&fsps)) != CB_SUCCESS)
|
||||||
|
die("On resume fsps header is invalid\n");
|
||||||
|
do_silicon_init(hdr);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (cbfs_boot_locate(&file_desc, name, NULL)) {
|
if (cbfs_boot_locate(&file_desc, name, NULL)) {
|
||||||
printk(BIOS_ERR, "Could not locate %s in CBFS\n", name);
|
printk(BIOS_ERR, "Could not locate %s in CBFS\n", name);
|
||||||
|
@ -98,6 +110,10 @@ void fsp_silicon_init(void)
|
||||||
if (fsp_validate_component(hdr, &rdev) != CB_SUCCESS)
|
if (fsp_validate_component(hdr, &rdev) != CB_SUCCESS)
|
||||||
die("Invalid FSPS header!\n");
|
die("Invalid FSPS header!\n");
|
||||||
|
|
||||||
|
prog_set_area(&fsps, dest, size);
|
||||||
|
|
||||||
|
stage_cache_add(STAGE_REFCODE, &fsps);
|
||||||
|
|
||||||
/* Signal that FSP component has been loaded. */
|
/* Signal that FSP component has been loaded. */
|
||||||
prog_segment_loaded(hdr->image_base, hdr->image_size, SEG_FINAL);
|
prog_segment_loaded(hdr->image_base, hdr->image_size, SEG_FINAL);
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <fsp/api.h>
|
#include <fsp/api.h>
|
||||||
#include <fsp/util.h>
|
#include <fsp/util.h>
|
||||||
|
#include <romstage_handoff.h>
|
||||||
#include <soc/iomap.h>
|
#include <soc/iomap.h>
|
||||||
#include <soc/cpu.h>
|
#include <soc/cpu.h>
|
||||||
#include <soc/intel/common/vbt.h>
|
#include <soc/intel/common/vbt.h>
|
||||||
|
@ -259,6 +260,7 @@ static void set_power_limits(void)
|
||||||
static void soc_init(void *data)
|
static void soc_init(void *data)
|
||||||
{
|
{
|
||||||
struct global_nvs_t *gnvs;
|
struct global_nvs_t *gnvs;
|
||||||
|
struct romstage_handoff *handoff;
|
||||||
|
|
||||||
/* Save VBT info and mapping */
|
/* Save VBT info and mapping */
|
||||||
vbt = vbt_get(&vbt_rdev);
|
vbt = vbt_get(&vbt_rdev);
|
||||||
|
@ -267,7 +269,8 @@ static void soc_init(void *data)
|
||||||
* default policy that doesn't honor boards' requirements. */
|
* default policy that doesn't honor boards' requirements. */
|
||||||
itss_snapshot_irq_polarities(GPIO_IRQ_START, GPIO_IRQ_END);
|
itss_snapshot_irq_polarities(GPIO_IRQ_START, GPIO_IRQ_END);
|
||||||
|
|
||||||
fsp_silicon_init();
|
handoff = romstage_handoff_find_or_add();
|
||||||
|
fsp_silicon_init(handoff->s3_resume);
|
||||||
|
|
||||||
/* Restore GPIO IRQ polarities back to previous settings. */
|
/* Restore GPIO IRQ polarities back to previous settings. */
|
||||||
itss_restore_irq_polarities(GPIO_IRQ_START, GPIO_IRQ_END);
|
itss_restore_irq_polarities(GPIO_IRQ_START, GPIO_IRQ_END);
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/device.h>
|
#include <device/device.h>
|
||||||
|
#include <romstage_handoff.h>
|
||||||
#include <soc/ramstage.h>
|
#include <soc/ramstage.h>
|
||||||
#include <soc/reg_access.h>
|
#include <soc/reg_access.h>
|
||||||
|
|
||||||
|
@ -101,6 +102,8 @@ static const struct reg_script thermal_init_script[] = {
|
||||||
|
|
||||||
static void chip_init(void *chip_info)
|
static void chip_init(void *chip_info)
|
||||||
{
|
{
|
||||||
|
struct romstage_handoff *handoff;
|
||||||
|
|
||||||
/* Validate the temperature settings */
|
/* Validate the temperature settings */
|
||||||
ASSERT(PLATFORM_CATASTROPHIC_TRIP_CELSIUS <= 255);
|
ASSERT(PLATFORM_CATASTROPHIC_TRIP_CELSIUS <= 255);
|
||||||
ASSERT(PLATFORM_CATASTROPHIC_TRIP_CELSIUS
|
ASSERT(PLATFORM_CATASTROPHIC_TRIP_CELSIUS
|
||||||
|
@ -117,7 +120,8 @@ static void chip_init(void *chip_info)
|
||||||
| TS_LOCK_AUX_TRIP_PT_REGS_ENABLE));
|
| TS_LOCK_AUX_TRIP_PT_REGS_ENABLE));
|
||||||
|
|
||||||
/* Perform silicon specific init. */
|
/* Perform silicon specific init. */
|
||||||
fsp_silicon_init();
|
handoff = romstage_handoff_find_or_add();
|
||||||
|
fsp_silicon_init(handoff->s3_resume);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pci_domain_set_resources(device_t dev)
|
static void pci_domain_set_resources(device_t dev)
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <fsp/api.h>
|
#include <fsp/api.h>
|
||||||
#include <fsp/util.h>
|
#include <fsp/util.h>
|
||||||
|
#include <romstage_handoff.h>
|
||||||
#include <soc/acpi.h>
|
#include <soc/acpi.h>
|
||||||
#include <soc/interrupt.h>
|
#include <soc/interrupt.h>
|
||||||
#include <soc/irq.h>
|
#include <soc/irq.h>
|
||||||
|
@ -34,8 +35,13 @@
|
||||||
|
|
||||||
void soc_init_pre_device(void *chip_info)
|
void soc_init_pre_device(void *chip_info)
|
||||||
{
|
{
|
||||||
|
struct romstage_handoff *handoff;
|
||||||
|
|
||||||
|
/* Get S3 status to pass to silicon init. */
|
||||||
|
handoff = romstage_handoff_find_or_add();
|
||||||
|
|
||||||
/* Perform silicon specific init. */
|
/* Perform silicon specific init. */
|
||||||
fsp_silicon_init();
|
fsp_silicon_init(handoff->s3_resume);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pci_domain_set_resources(device_t dev)
|
static void pci_domain_set_resources(device_t dev)
|
||||||
|
|
Loading…
Reference in a new issue