aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Jones <ajones@ventanamicro.com>2023-05-15 13:12:37 +0200
committerAnup Patel <anup@brainfault.org>2023-05-21 16:53:02 +0530
commit8b952d4fcd4e1341ed7061bd01b8b12802031ea1 (patch)
tree9922710d57681bd30fb28f5a3afe48f26af6dd8b
parent042f0c3ea25e995a6db93cd64964b816cb8ffba4 (diff)
downloadopensbi-8b952d4fcd4e1341ed7061bd01b8b12802031ea1.zip
opensbi-8b952d4fcd4e1341ed7061bd01b8b12802031ea1.tar.gz
opensbi-8b952d4fcd4e1341ed7061bd01b8b12802031ea1.tar.bz2
lib: sbi: Only register available extensions
When an extension implements a probe function it means there's a chance that the extension is not available. Use this function in the register_extensions callback to determine if the extension should be registered at all. Where the probe implementation is simple, just open code the check. Signed-off-by: Andrew Jones <ajones@ventanamicro.com> Reviewed-by: Anup Patel <anup@brainfault.org>
-rw-r--r--lib/sbi/sbi_ecall_cppc.c3
-rw-r--r--lib/sbi/sbi_ecall_dbcn.c3
-rw-r--r--lib/sbi/sbi_ecall_srst.c6
-rw-r--r--lib/sbi/sbi_ecall_susp.c6
-rw-r--r--lib/sbi/sbi_ecall_vendor.c17
-rw-r--r--lib/sbi/sbi_init.c22
6 files changed, 35 insertions, 22 deletions
diff --git a/lib/sbi/sbi_ecall_cppc.c b/lib/sbi/sbi_ecall_cppc.c
index 42ec744..a6398ac 100644
--- a/lib/sbi/sbi_ecall_cppc.c
+++ b/lib/sbi/sbi_ecall_cppc.c
@@ -59,6 +59,9 @@ struct sbi_ecall_extension ecall_cppc;
static int sbi_ecall_cppc_register_extensions(void)
{
+ if (!sbi_cppc_get_device())
+ return 0;
+
return sbi_ecall_register_extension(&ecall_cppc);
}
diff --git a/lib/sbi/sbi_ecall_dbcn.c b/lib/sbi/sbi_ecall_dbcn.c
index 58b19e4..cbb2e80 100644
--- a/lib/sbi/sbi_ecall_dbcn.c
+++ b/lib/sbi/sbi_ecall_dbcn.c
@@ -68,6 +68,9 @@ struct sbi_ecall_extension ecall_dbcn;
static int sbi_ecall_dbcn_register_extensions(void)
{
+ if (!sbi_console_get_device())
+ return 0;
+
return sbi_ecall_register_extension(&ecall_dbcn);
}
diff --git a/lib/sbi/sbi_ecall_srst.c b/lib/sbi/sbi_ecall_srst.c
index ad31537..ea0dc73 100644
--- a/lib/sbi/sbi_ecall_srst.c
+++ b/lib/sbi/sbi_ecall_srst.c
@@ -71,6 +71,12 @@ struct sbi_ecall_extension ecall_srst;
static int sbi_ecall_srst_register_extensions(void)
{
+ unsigned long out_val;
+
+ sbi_ecall_srst_probe(SBI_EXT_SRST, &out_val);
+ if (!out_val)
+ return 0;
+
return sbi_ecall_register_extension(&ecall_srst);
}
diff --git a/lib/sbi/sbi_ecall_susp.c b/lib/sbi/sbi_ecall_susp.c
index bfbdbe6..c412404 100644
--- a/lib/sbi/sbi_ecall_susp.c
+++ b/lib/sbi/sbi_ecall_susp.c
@@ -44,6 +44,12 @@ struct sbi_ecall_extension ecall_susp;
static int sbi_ecall_susp_register_extensions(void)
{
+ unsigned long out_val;
+
+ sbi_ecall_susp_probe(SBI_EXT_SUSP, &out_val);
+ if (!out_val)
+ return 0;
+
return sbi_ecall_register_extension(&ecall_susp);
}
diff --git a/lib/sbi/sbi_ecall_vendor.c b/lib/sbi/sbi_ecall_vendor.c
index 39c58c8..700f475 100644
--- a/lib/sbi/sbi_ecall_vendor.c
+++ b/lib/sbi/sbi_ecall_vendor.c
@@ -22,24 +22,11 @@ static inline unsigned long sbi_ecall_vendor_id(void)
(SBI_EXT_VENDOR_END - SBI_EXT_VENDOR_START));
}
-static int sbi_ecall_vendor_probe(unsigned long extid,
- unsigned long *out_val)
-{
- if (!sbi_platform_vendor_ext_check(sbi_platform_thishart_ptr()))
- *out_val = 0;
- else
- *out_val = 1;
- return 0;
-}
-
static int sbi_ecall_vendor_handler(unsigned long extid, unsigned long funcid,
const struct sbi_trap_regs *regs,
unsigned long *out_val,
struct sbi_trap_info *out_trap)
{
- if (!sbi_platform_vendor_ext_check(sbi_platform_thishart_ptr()))
- return SBI_ERR_NOT_SUPPORTED;
-
return sbi_platform_vendor_ext_provider(sbi_platform_thishart_ptr(),
funcid, regs,
out_val, out_trap);
@@ -51,6 +38,9 @@ static int sbi_ecall_vendor_register_extensions(void)
{
unsigned long extid = sbi_ecall_vendor_id();
+ if (!sbi_platform_vendor_ext_check(sbi_platform_thishart_ptr()))
+ return 0;
+
ecall_vendor.extid_start = extid;
ecall_vendor.extid_end = extid;
@@ -61,6 +51,5 @@ struct sbi_ecall_extension ecall_vendor = {
.extid_start = SBI_EXT_VENDOR_START,
.extid_end = SBI_EXT_VENDOR_END,
.register_extensions = sbi_ecall_vendor_register_extensions,
- .probe = sbi_ecall_vendor_probe,
.handle = sbi_ecall_vendor_handler,
};
diff --git a/lib/sbi/sbi_init.c b/lib/sbi/sbi_init.c
index 539f824..7c78d9b 100644
--- a/lib/sbi/sbi_init.c
+++ b/lib/sbi/sbi_init.c
@@ -323,12 +323,6 @@ static void __noreturn init_coldboot(struct sbi_scratch *scratch, u32 hartid)
sbi_hart_hang();
}
- rc = sbi_ecall_init();
- if (rc) {
- sbi_printf("%s: ecall init failed (error %d)\n", __func__, rc);
- sbi_hart_hang();
- }
-
/*
* Note: Finalize domains after HSM initialization so that we
* can startup non-root domains.
@@ -350,8 +344,9 @@ static void __noreturn init_coldboot(struct sbi_scratch *scratch, u32 hartid)
}
/*
- * Note: Platform final initialization should be last so that
- * it sees correct domain assignment and PMP configuration.
+ * Note: Platform final initialization should be after finalizing
+ * domains so that it sees correct domain assignment and PMP
+ * configuration for FDT fixups.
*/
rc = sbi_platform_final_init(plat, true);
if (rc) {
@@ -360,6 +355,17 @@ static void __noreturn init_coldboot(struct sbi_scratch *scratch, u32 hartid)
sbi_hart_hang();
}
+ /*
+ * Note: Ecall initialization should be after platform final
+ * initialization so that all available platform devices are
+ * already registered.
+ */
+ rc = sbi_ecall_init();
+ if (rc) {
+ sbi_printf("%s: ecall init failed (error %d)\n", __func__, rc);
+ sbi_hart_hang();
+ }
+
sbi_boot_print_general(scratch);
sbi_boot_print_domains(scratch);