summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnup Patel <anup.patel@wdc.com>2021-04-09 06:50:08 +0300
committerAnup Patel <anup@brainfault.org>2021-04-13 08:26:32 +0300
commitb1df1acd201e388a5ce96fd045593ee5b29c0387 (patch)
treeddbfd3557c44213d1a2086f5431ec6af3bd2c54d
parent27a16b1545f750bc4d15d46a737a4411861bd9d3 (diff)
downloadopensbi-b1df1acd201e388a5ce96fd045593ee5b29c0387.tar.xz
lib: sbi: Domains can be registered only before finalizing domains
The domains are boot-time system-level partitions so we should allow platform support to register domains only before hart domain assignments are finalized. Signed-off-by: Anup Patel <anup.patel@wdc.com> Reviewed-by: Xiang W <wxjstz@126.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
-rw-r--r--lib/sbi/sbi_domain.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/lib/sbi/sbi_domain.c b/lib/sbi/sbi_domain.c
index 195c941..2849241 100644
--- a/lib/sbi/sbi_domain.c
+++ b/lib/sbi/sbi_domain.c
@@ -19,8 +19,8 @@
struct sbi_domain *hartid_to_domain_table[SBI_HARTMASK_MAX_BITS] = { 0 };
struct sbi_domain *domidx_to_domain_table[SBI_DOMAIN_MAX_INDEX] = { 0 };
-
static u32 domain_count = 0;
+static bool domain_finalized = false;
static struct sbi_hartmask root_hmask = { 0 };
@@ -376,7 +376,8 @@ int sbi_domain_register(struct sbi_domain *dom,
u32 cold_hartid = current_hartid();
const struct sbi_platform *plat = sbi_platform_thishart_ptr();
- if (!dom || !assign_mask)
+ /* Sanity checks */
+ if (!dom || !assign_mask || domain_finalized)
return SBI_EINVAL;
/* Check if domain already discovered */
@@ -490,6 +491,12 @@ int sbi_domain_finalize(struct sbi_scratch *scratch, u32 cold_hartid)
}
}
+ /*
+ * Set the finalized flag so that the root domain
+ * regions can't be changed.
+ */
+ domain_finalized = true;
+
return 0;
}