post_code: add post code for failure to load next stage

Add a new post code, POST_INVALID_ROM, used when coreboot fails to
locate or validate a resource that is stored in ROM.

BUG=b:124401932
BRANCH=sarien
TEST=build coreboot for sarien and arcada platforms

Change-Id: Ie6de6590595d8fcdc57ad156237fffa03d5ead38
Signed-off-by: Keith Short <keithshort@chromium.org>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/32770
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Reviewed-by: Duncan Laurie <dlaurie@chromium.org>
This commit is contained in:
Keith Short
2019-05-06 16:12:57 -06:00
committed by Duncan Laurie
parent ba44a27f7f
commit 7006458777
5 changed files with 24 additions and 9 deletions

View File

@ -69,7 +69,8 @@ void run_romstage(void)
fail:
if (CONFIG(BOOTBLOCK_CONSOLE))
die("Couldn't load romstage.\n");
die_with_post_code(POST_INVALID_ROM,
"Couldn't load romstage.\n");
halt();
}
@ -162,7 +163,7 @@ void run_ramstage(void)
prog_run(&ramstage);
fail:
die("Ramstage was not loaded!\n");
die_with_post_code(POST_INVALID_ROM, "Ramstage was not loaded!\n");
}
#ifdef __RAMSTAGE__ // gc-sections should take care of this
@ -195,13 +196,14 @@ void payload_load(void)
break;
} /* else fall-through */
default:
die("Unsupported payload type.\n");
die_with_post_code(POST_INVALID_ROM,
"Unsupported payload type.\n");
break;
}
out:
if (prog_entry(payload) == NULL)
die("Payload not loaded.\n");
die_with_post_code(POST_INVALID_ROM, "Payload not loaded.\n");
}
void payload_run(void)