diff options
author | Anup Patel <apatel@ventanamicro.com> | 2022-12-29 05:56:16 +0300 |
---|---|---|
committer | Anup Patel <anup@brainfault.org> | 2023-01-07 13:28:52 +0300 |
commit | 6957ae0e91ebd9f17411b56f3e9100d31bc48b56 (patch) | |
tree | 957c5c1e59397283cc4013528d131eea5d5c6253 | |
parent | f14595a7cfc8de16a06335c6ecdf9ae23a0adf53 (diff) | |
download | opensbi-6957ae0e91ebd9f17411b56f3e9100d31bc48b56.tar.xz |
platform: generic: Allow platform_override to select cold boot HART
We add a generic platform override callback to allow platform specific
selection of cold boot HART.
Signed-off-by: Anup Patel <apatel@ventanamicro.com>
-rw-r--r-- | platform/generic/include/platform_override.h | 1 | ||||
-rw-r--r-- | platform/generic/platform.c | 9 |
2 files changed, 10 insertions, 0 deletions
diff --git a/platform/generic/include/platform_override.h b/platform/generic/include/platform_override.h index 7f1558d..21354e9 100644 --- a/platform/generic/include/platform_override.h +++ b/platform/generic/include/platform_override.h @@ -18,6 +18,7 @@ struct platform_override { const struct fdt_match *match_table; u64 (*features)(const struct fdt_match *match); u64 (*tlbr_flush_limit)(const struct fdt_match *match); + bool (*cold_boot_allowed)(u32 hartid, const struct fdt_match *match); int (*early_init)(bool cold_boot, const struct fdt_match *match); int (*final_init)(bool cold_boot, const struct fdt_match *match); void (*early_exit)(const struct fdt_match *match); diff --git a/platform/generic/platform.c b/platform/generic/platform.c index bfe15f0..5fb0dc6 100644 --- a/platform/generic/platform.c +++ b/platform/generic/platform.c @@ -122,6 +122,14 @@ fail: wfi(); } +static bool generic_cold_boot_allowed(u32 hartid) +{ + if (generic_plat && generic_plat->cold_boot_allowed) + return generic_plat->cold_boot_allowed( + hartid, generic_plat_match); + return true; +} + static int generic_nascent_init(void) { if (platform_has_mlevel_imsic) @@ -261,6 +269,7 @@ static int generic_console_init(void) } const struct sbi_platform_operations platform_ops = { + .cold_boot_allowed = generic_cold_boot_allowed, .nascent_init = generic_nascent_init, .early_init = generic_early_init, .final_init = generic_final_init, |