lib/program_loaders.c: Mark run_ramstage with __noreturn
This allows the compiler to optimize out code called after run_ramstage.
Also remove some die() statements in soc code as run_ramstage already
has a die_with_postcode statement.
Change-Id: Id8b841712661d3257b0dc67b509f97bdc31fcf6f
Signed-off-by: Arthur Heymans <arthur@aheymans.xyz>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/65811
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Felix Held <felix-coreboot@felixheld.de>
Reviewed-by: Julius Werner <jwerner@chromium.org>
diff --git a/src/include/program_loading.h b/src/include/program_loading.h
index 7ff55fc..e53cb7c 100644
--- a/src/include/program_loading.h
+++ b/src/include/program_loading.h
@@ -152,7 +152,7 @@
*/
void preload_ramstage(void);
/* Run ramstage from romstage. */
-void run_ramstage(void);
+void __noreturn run_ramstage(void);
/***********************
* PAYLOAD LOADING *
diff --git a/src/lib/prog_loaders.c b/src/lib/prog_loaders.c
index 0139ca4..01775b9 100644
--- a/src/lib/prog_loaders.c
+++ b/src/lib/prog_loaders.c
@@ -82,7 +82,7 @@
cbfs_preload(CONFIG_CBFS_PREFIX "/ramstage");
}
-void run_ramstage(void)
+void __noreturn run_ramstage(void)
{
struct prog ramstage =
PROG_INIT(PROG_RAMSTAGE, CONFIG_CBFS_PREFIX "/ramstage");
diff --git a/src/soc/amd/cezanne/romstage.c b/src/soc/amd/cezanne/romstage.c
index 7a395bd..dce0b69 100644
--- a/src/soc/amd/cezanne/romstage.c
+++ b/src/soc/amd/cezanne/romstage.c
@@ -25,5 +25,4 @@
memmap_stash_early_dram_usage();
run_ramstage();
- die("failed to load ramstage\n");
}
diff --git a/src/soc/amd/picasso/romstage.c b/src/soc/amd/picasso/romstage.c
index e66f423..ccb11f0 100644
--- a/src/soc/amd/picasso/romstage.c
+++ b/src/soc/amd/picasso/romstage.c
@@ -25,7 +25,4 @@
post_code(0x44);
run_ramstage();
-
- post_code(0x50); /* Should never see this post code. */
- die("failed to load ramstage\n");
}
diff --git a/src/soc/amd/sabrina/romstage.c b/src/soc/amd/sabrina/romstage.c
index c5dfbda..9f2be8e 100644
--- a/src/soc/amd/sabrina/romstage.c
+++ b/src/soc/amd/sabrina/romstage.c
@@ -27,5 +27,4 @@
memmap_stash_early_dram_usage();
run_ramstage();
- die("failed to load ramstage\n");
}