chromeos/vboot: allow platform to hook into vboot_reboot()

Sometimes it's necessary for the platform to perform clean up
tasks prior to reboot when employing vboot. For example, x86 systems
that resume and do vboot verification may need to clear their
sleep control register prior to doing a cold reset so that the
next boot doesn't appear to be a resume. Allow that hook by
introducing vboot_platform_prepare_reboot().

BUG=chrome-os-partner:46049
BRANCH=glados
TEST=Ensure vboot_platform_prepare_reboot() called from vboot_reboot().

Change-Id: I622c9181d9fa3048204e3df3223d5dd4b458abca
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Original-Commit-Id: f31ffc40bde002dec398fd4dd9d2ee9d65df0d7b
Original-Change-Id: I97318cec34494a7fc4b1ecf2cb22715d20e730ff
Original-Signed-off-by: Aaron Durbin <adurbin@chromium.org>
Original-Reviewed-on: https://chromium-review.googlesource.com/323501
Original-Reviewed-by: Patrick Georgi <pgeorgi@chromium.org>
Original-Reviewed-by: Duncan Laurie <dlaurie@chromium.org>
Reviewed-on: https://review.coreboot.org/13575
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
This commit is contained in:
Aaron Durbin 2016-01-22 16:33:57 -06:00 committed by Patrick Georgi
parent 87c9faeb4c
commit 5dbefd9ff6
2 changed files with 8 additions and 0 deletions

View File

@ -92,10 +92,15 @@ int vboot_recovery_reason(void)
return sd->recovery_reason; return sd->recovery_reason;
} }
void __attribute__((weak)) vboot_platform_prepare_reboot(void)
{
}
void vboot_reboot(void) void vboot_reboot(void)
{ {
if (IS_ENABLED(CONFIG_CONSOLE_CBMEM_DUMP_TO_UART)) if (IS_ENABLED(CONFIG_CONSOLE_CBMEM_DUMP_TO_UART))
cbmem_dump_console(); cbmem_dump_console();
vboot_platform_prepare_reboot();
hard_reset(); hard_reset();
die("failed to reboot"); die("failed to reboot");
} }

View File

@ -64,6 +64,9 @@ int vboot_retrieve_hash(void *digest, size_t digest_size);
*/ */
int vboot_platform_is_resuming(void); int vboot_platform_is_resuming(void);
/* Allow the platform to do any clean up work when vboot requests a reboot. */
void vboot_platform_prepare_reboot(void);
/* Main logic for verified boot. verstage() is the stage entry point /* Main logic for verified boot. verstage() is the stage entry point
* while the verstage_main() is just the core logic. */ * while the verstage_main() is just the core logic. */
void verstage_main(void); void verstage_main(void);