ec/google/wilco: set diagnostic LEDs on boot failure

On Wilco devices, if any of the coreboot stages fails with a fatal
error, set the diagnostic LEDs with the Wilco EC.  The last saved
post code is used to determine the error code sent to the EC.

BUG=b:124401932
BRANCH=sarien
TEST=build coreboot for sarien and arcada platforms
TEST=Remove DIMM module, confirm diagnostic LED pattern for memory
failure (2 amber, 4 white).
TEST=Forced a fatal error in both bootblock and verstage to confirm
diagnostic LEDs during these stages. This works on cold-boots only. Bug
b:132622888 tracks the mailbox failures on warm boots.

Change-Id: If865ab8203f89e499130f4677fec166b40d80174
Signed-off-by: Keith Short <keithshort@chromium.org>
Signed-off-by: Duncan Laurie <dlaurie@google.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/32777
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Jett Rink <jettrink@chromium.org>
Reviewed-by: Duncan Laurie <dlaurie@chromium.org>
Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
Keith Short 2019-05-10 11:52:55 -06:00 committed by Duncan Laurie
parent c58e3bd90a
commit f41afde6c2
2 changed files with 46 additions and 11 deletions

View file

@ -182,8 +182,45 @@ int wilco_ec_signed_fw(void)
return !!ec_read(EC_RAM_SIGNED_FW); return !!ec_read(EC_RAM_SIGNED_FW);
} }
int wilco_ec_err_code(enum ec_err_code err_code) struct err_code_entry {
uint8_t post_code;
enum ec_err_code ec_err;
};
/*
* Any post codes not listed in the post_code_err_map[] use default.
*/
static const enum ec_err_code default_ec_err = DLED_ROM;
static const struct err_code_entry post_code_err_map[] = {
{ .post_code = POST_RAM_FAILURE, .ec_err = DLED_MEMORY, },
{ .post_code = POST_VIDEO_FAILURE, .ec_err = DLED_PANEL, },
};
/* Records the most recent post code during boot */
static uint8_t wilco_ec_saved_post_code;
void wilco_ec_save_post_code(uint8_t post_code)
{ {
return wilco_ec_mailbox(WILCO_EC_MSG_DEFAULT, KB_ERR_CODE, wilco_ec_saved_post_code = post_code;
&err_code, 1, NULL, 0); }
/* Send error code to the EC based on last saved post code */
void die_notify(void)
{
size_t i;
enum ec_err_code err_code = default_ec_err;
for (i = 0; i < ARRAY_SIZE(post_code_err_map); i++) {
if (post_code_err_map[i].post_code ==
wilco_ec_saved_post_code) {
err_code = post_code_err_map[i].ec_err;
break;
}
}
printk(BIOS_EMERG, "Fatal error: post_code 0x%02x, EC err 0x%02x\n",
wilco_ec_saved_post_code, err_code);
wilco_ec_mailbox(WILCO_EC_MSG_DEFAULT, KB_ERR_CODE,
&err_code, 1, NULL, 0);
} }

View file

@ -319,16 +319,14 @@ enum ec_acpi_wake_events {
int wilco_ec_signed_fw(void); int wilco_ec_signed_fw(void);
/** /**
* wilco_ec_err_code * wilco_ec_save_post_code
* *
* Send an error code to the EC to indicate a failed boot. The EC flashes the * Save this post code as the most recent progress step. If the boot fails
* platform LED amber and white to provide user indication of the failure type. * and calls die_notify() this post code will be used to send an error code
* to the EC indicating the failure.
* *
* @err_code: Error code to send to the EC * @post_code: Post code to save
*
* Returns 0 if EC command was successful
* Returns -1 if EC command failed
*/ */
int wilco_ec_err_code(enum ec_err_code err_code); void wilco_ec_save_post_code(uint8_t post_code);
#endif /* EC_GOOGLE_WILCO_COMMANDS_H */ #endif /* EC_GOOGLE_WILCO_COMMANDS_H */