soc/intel,chromeos: Fix EC RO/RW status in GNVS

For baytrail and braswell, explicitly initialise
it to ACTIVE_ECFW_RO without ChromeEC.

For broadwell and skylake, fix it to report actual
google_ec_running_ro() status.

Change-Id: I30236c41c9261fd9f8565e1c5fdbfe6f46114e28
Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/42389
Reviewed-by: Furquan Shaikh <furquan@google.com>
Reviewed-by: Angel Pons <th3fanbus@gmail.com>
Reviewed-by: Matt DeVillier <matt.devillier@gmail.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Kyösti Mälkki 2020-06-15 13:04:48 +03:00 committed by Angel Pons
parent 7ac76ecf91
commit 000d91af00
4 changed files with 40 additions and 34 deletions
src/soc/intel
baytrail
braswell
broadwell
skylake

View file

@ -73,14 +73,16 @@ void acpi_init_gnvs(global_nvs_t *gnvs)
gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE); gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE);
#endif #endif
#if CONFIG(CHROMEOS) if (CONFIG(CHROMEOS)) {
/* Initialize Verified Boot data */ /* Initialize Verified Boot data */
chromeos_init_chromeos_acpi(&(gnvs->chromeos)); chromeos_init_chromeos_acpi(&(gnvs->chromeos));
#if CONFIG(EC_GOOGLE_CHROMEEC) if (CONFIG(EC_GOOGLE_CHROMEEC)) {
gnvs->chromeos.vbt2 = google_ec_running_ro() ? gnvs->chromeos.vbt2 = google_ec_running_ro() ?
ACTIVE_ECFW_RO : ACTIVE_ECFW_RW; ACTIVE_ECFW_RO : ACTIVE_ECFW_RW;
#endif } else {
#endif gnvs->chromeos.vbt2 = ACTIVE_ECFW_RO;
}
}
} }
static int acpi_sci_irq(void) static int acpi_sci_irq(void)

View file

@ -77,14 +77,16 @@ void acpi_init_gnvs(global_nvs_t *gnvs)
gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE); gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE);
#endif #endif
#if CONFIG(CHROMEOS) if (CONFIG(CHROMEOS)) {
/* Initialize Verified Boot data */ /* Initialize Verified Boot data */
chromeos_init_chromeos_acpi(&(gnvs->chromeos)); chromeos_init_chromeos_acpi(&(gnvs->chromeos));
#if CONFIG(EC_GOOGLE_CHROMEEC) if (CONFIG(EC_GOOGLE_CHROMEEC)) {
gnvs->chromeos.vbt2 = google_ec_running_ro() ? gnvs->chromeos.vbt2 = google_ec_running_ro() ?
ACTIVE_ECFW_RO : ACTIVE_ECFW_RW; ACTIVE_ECFW_RO : ACTIVE_ECFW_RW;
#endif } else {
#endif gnvs->chromeos.vbt2 = ACTIVE_ECFW_RO;
}
}
} }
static int acpi_sci_irq(void) static int acpi_sci_irq(void)

View file

@ -161,15 +161,16 @@ void acpi_init_gnvs(global_nvs_t *gnvs)
gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE); gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE);
#endif #endif
#if CONFIG(CHROMEOS) if (CONFIG(CHROMEOS)) {
/* Initialize Verified Boot data */ /* Initialize Verified Boot data */
chromeos_init_chromeos_acpi(&(gnvs->chromeos)); chromeos_init_chromeos_acpi(&(gnvs->chromeos));
#if CONFIG(EC_GOOGLE_CHROMEEC) if (CONFIG(EC_GOOGLE_CHROMEEC)) {
gnvs->chromeos.vbt2 = google_ec_running_ro() ? gnvs->chromeos.vbt2 = google_ec_running_ro() ?
ACTIVE_ECFW_RO : ACTIVE_ECFW_RW; ACTIVE_ECFW_RO : ACTIVE_ECFW_RW;
#endif } else {
gnvs->chromeos.vbt2 = ACTIVE_ECFW_RO; gnvs->chromeos.vbt2 = ACTIVE_ECFW_RO;
#endif }
}
} }
unsigned long acpi_fill_mcfg(unsigned long current) unsigned long acpi_fill_mcfg(unsigned long current)

View file

@ -170,15 +170,16 @@ static void acpi_create_gnvs(global_nvs_t *gnvs)
gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE); gnvs->cbmc = (u32)cbmem_find(CBMEM_ID_CONSOLE);
#endif #endif
#if CONFIG(CHROMEOS) if (CONFIG(CHROMEOS)) {
/* Initialize Verified Boot data */ /* Initialize Verified Boot data */
chromeos_init_chromeos_acpi(&(gnvs->chromeos)); chromeos_init_chromeos_acpi(&(gnvs->chromeos));
#if CONFIG(EC_GOOGLE_CHROMEEC) if (CONFIG(EC_GOOGLE_CHROMEEC)) {
gnvs->chromeos.vbt2 = google_ec_running_ro() ? gnvs->chromeos.vbt2 = google_ec_running_ro() ?
ACTIVE_ECFW_RO : ACTIVE_ECFW_RW; ACTIVE_ECFW_RO : ACTIVE_ECFW_RW;
#endif } else {
gnvs->chromeos.vbt2 = ACTIVE_ECFW_RO; gnvs->chromeos.vbt2 = ACTIVE_ECFW_RO;
#endif }
}
/* Enable DPTF based on mainboard configuration */ /* Enable DPTF based on mainboard configuration */
gnvs->dpte = config->dptf_enable; gnvs->dpte = config->dptf_enable;