soc/amd/picasso: Refactor transfer buffer check
The transfer buffer check had gotten large enough to deserve a function of its own, so break it out. BUG=None TEST=Build Branch=Zork Signed-off-by: Martin Roth <martinroth@chromium.org> Change-Id: Idf46f8edb6b70c63f623522e2bcd2f22d6d4790b Reviewed-on: https://review.coreboot.org/c/coreboot/+/46112 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com> Reviewed-by: Edward O'Callaghan <quasisec@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
fc33235f82
commit
4b34193d59
4 changed files with 39 additions and 25 deletions
|
@ -24,6 +24,7 @@ bootblock-y += smi_util.c
|
||||||
bootblock-y += config.c
|
bootblock-y += config.c
|
||||||
bootblock-y += pmutil.c
|
bootblock-y += pmutil.c
|
||||||
bootblock-y += reset.c
|
bootblock-y += reset.c
|
||||||
|
bootblock-$(CONFIG_VBOOT_STARTS_BEFORE_BOOTBLOCK) += bootblock/vboot_bootblock.c
|
||||||
|
|
||||||
romstage-y += i2c.c
|
romstage-y += i2c.c
|
||||||
romstage-y += romstage.c
|
romstage-y += romstage.c
|
||||||
|
|
|
@ -16,14 +16,8 @@
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <amdblocks/amd_pci_mmconf.h>
|
#include <amdblocks/amd_pci_mmconf.h>
|
||||||
#include <acpi/acpi.h>
|
#include <acpi/acpi.h>
|
||||||
#include <security/vboot/symbols.h>
|
|
||||||
#include <security/vboot/vbnv.h>
|
#include <security/vboot/vbnv.h>
|
||||||
|
|
||||||
/* vboot includes directory may not be in include path if vboot is not enabled */
|
|
||||||
#if CONFIG(VBOOT_STARTS_BEFORE_BOOTBLOCK)
|
|
||||||
#include <2struct.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
asmlinkage void bootblock_resume_entry(void);
|
asmlinkage void bootblock_resume_entry(void);
|
||||||
|
|
||||||
/* PSP performs the memory training and setting up DRAM map prior to x86 cores
|
/* PSP performs the memory training and setting up DRAM map prior to x86 cores
|
||||||
|
@ -133,26 +127,9 @@ void bootblock_soc_init(void)
|
||||||
u32 val = cpuid_eax(1);
|
u32 val = cpuid_eax(1);
|
||||||
printk(BIOS_DEBUG, "Family_Model: %08x\n", val);
|
printk(BIOS_DEBUG, "Family_Model: %08x\n", val);
|
||||||
|
|
||||||
#if CONFIG(VBOOT_STARTS_BEFORE_BOOTBLOCK)
|
if (CONFIG(VBOOT_STARTS_BEFORE_BOOTBLOCK)) {
|
||||||
if (*(uint32_t *)_vboot2_work != VB2_SHARED_DATA_MAGIC) {
|
verify_psp_transfer_buf();
|
||||||
/*
|
|
||||||
* If the system has already been rebooted once, but still returns here,
|
|
||||||
* instead of rebooting to verstage again, assume that the system is in
|
|
||||||
* a reboot loop, so halt instead.
|
|
||||||
*/
|
|
||||||
if ((!vbnv_cmos_failed()) && cmos_read(CMOS_RECOVERY_BYTE) ==
|
|
||||||
CMOS_RECOVERY_MAGIC_VAL)
|
|
||||||
die("Error: Reboot into recovery was unsuccessful. Halting.");
|
|
||||||
|
|
||||||
printk(BIOS_ERR, "ERROR: VBOOT workbuf not valid.\n");
|
|
||||||
printk(BIOS_DEBUG, "Signature: %#08x\n", *(uint32_t *)_vboot2_work);
|
|
||||||
cmos_init(0);
|
|
||||||
cmos_write(CMOS_RECOVERY_MAGIC_VAL, CMOS_RECOVERY_BYTE);
|
|
||||||
warm_reset();
|
|
||||||
} else {
|
|
||||||
cmos_write(0x00, CMOS_RECOVERY_BYTE);
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
fch_early_init();
|
fch_early_init();
|
||||||
}
|
}
|
||||||
|
|
32
src/soc/amd/picasso/bootblock/vboot_bootblock.c
Normal file
32
src/soc/amd/picasso/bootblock/vboot_bootblock.c
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
|
|
||||||
|
#include <amdblocks/reset.h>
|
||||||
|
#include <console/console.h>
|
||||||
|
#include <pc80/mc146818rtc.h>
|
||||||
|
#include <security/vboot/vbnv.h>
|
||||||
|
#include <security/vboot/symbols.h>
|
||||||
|
#include <soc/psp_transfer.h>
|
||||||
|
#include <2struct.h>
|
||||||
|
|
||||||
|
void verify_psp_transfer_buf(void)
|
||||||
|
{
|
||||||
|
if (*(uint32_t *)_vboot2_work == VB2_SHARED_DATA_MAGIC) {
|
||||||
|
cmos_write(0x00, CMOS_RECOVERY_BYTE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If CMOS is valid and the system has already been rebooted once, but
|
||||||
|
* still returns here, instead of rebooting to verstage again, assume
|
||||||
|
* that the system is in a reboot loop and halt.
|
||||||
|
*/
|
||||||
|
if ((!vbnv_cmos_failed()) && cmos_read(CMOS_RECOVERY_BYTE) ==
|
||||||
|
CMOS_RECOVERY_MAGIC_VAL)
|
||||||
|
die("Error: Reboot into recovery was unsuccessful. Halting.");
|
||||||
|
|
||||||
|
printk(BIOS_ERR, "ERROR: VBOOT workbuf not valid.\n");
|
||||||
|
printk(BIOS_DEBUG, "Signature: %#08x\n", *(uint32_t *)_vboot2_work);
|
||||||
|
cmos_init(0);
|
||||||
|
cmos_write(CMOS_RECOVERY_MAGIC_VAL, CMOS_RECOVERY_BYTE);
|
||||||
|
warm_reset();
|
||||||
|
}
|
|
@ -41,6 +41,10 @@ struct transfer_info_struct {
|
||||||
|
|
||||||
_Static_assert(sizeof(struct transfer_info_struct) == TRANSFER_INFO_SIZE, \
|
_Static_assert(sizeof(struct transfer_info_struct) == TRANSFER_INFO_SIZE, \
|
||||||
"TRANSFER_INFO_SIZE is incorrect");
|
"TRANSFER_INFO_SIZE is incorrect");
|
||||||
|
|
||||||
|
/* Make sure the PSP transferred information over to x86 side. */
|
||||||
|
void verify_psp_transfer_buf(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* PSP_VERSTAGE_PSP_TRANSFER_H */
|
#endif /* PSP_VERSTAGE_PSP_TRANSFER_H */
|
||||||
|
|
Loading…
Reference in a new issue