include: sbi: Introduce nascent_init() platform callback
authorAnup Patel <apatel@ventanamicro.com>
Tue, 29 Jun 2021 07:44:04 +0000 (13:14 +0530)
committerAnup Patel <anup@brainfault.org>
Tue, 15 Feb 2022 15:04:24 +0000 (20:34 +0530)
We introduce nascent_init() platform callback which will allow
platforms to do very early initialization of platform specific
per-HART CSRs and per-HART devices.

Signed-off-by: Anup Patel <anup.patel@wdc.com>
Signed-off-by: Anup Patel <apatel@ventanamicro.com>
Reviewed-by: Atish Patra <atishp@rivosinc.com>
include/sbi/sbi_platform.h
lib/sbi/sbi_init.c

index 4d192f2..0b5ae4b 100644 (file)
@@ -64,6 +64,9 @@ enum sbi_platform_features {
 
 /** Platform functions */
 struct sbi_platform_operations {
+       /* Platform nascent initialization */
+       int (*nascent_init)(void);
+
        /** Platform early initialization */
        int (*early_init)(bool cold_boot);
        /** Platform final initialization */
@@ -300,6 +303,23 @@ static inline bool sbi_platform_hart_invalid(const struct sbi_platform *plat,
 }
 
 /**
+ * Nascent (very early) initialization for current HART
+ *
+ * NOTE: This function can be used to do very early initialization of
+ * platform specific per-HART CSRs and devices.
+ *
+ * @param plat pointer to struct sbi_platform
+ *
+ * @return 0 on success and negative error code on failure
+ */
+static inline int sbi_platform_nascent_init(const struct sbi_platform *plat)
+{
+       if (plat && sbi_platform_ops(plat)->nascent_init)
+               return sbi_platform_ops(plat)->nascent_init();
+       return 0;
+}
+
+/**
  * Early initialization for current HART
  *
  * @param plat pointer to struct sbi_platform
index 83043c5..27d03a7 100644 (file)
@@ -494,6 +494,14 @@ void __noreturn sbi_init(struct sbi_scratch *scratch)
        if (next_mode_supported && atomic_xchg(&coldboot_lottery, 1) == 0)
                coldboot = TRUE;
 
+       /*
+        * Do platform specific nascent (very early) initialization so
+        * that platform can initialize platform specific per-HART CSRs
+        * or per-HART devices.
+        */
+       if (sbi_platform_nascent_init(plat))
+               sbi_hart_hang();
+
        if (coldboot)
                init_coldboot(scratch, hartid);
        else