[RFC PATCH 10/12] lib: utils: fdt_domain: parse per-domain WID properties
Yu-Chien Peter Lin
peter.lin at sifive.com
Fri Jun 26 03:14:31 PDT 2026
Extends __fdt_parse_domain() to parse next-wid (32-bit WID) and
next-widlist (64-bit delegation mask) from domain DT nodes. Enables
per-domain World ID configuration. Stores in sbi_domain structure
for mlwid/mwiddeleg CSR programming during domain context switches.
Signed-off-by: Yu-Chien Peter Lin <peter.lin at sifive.com>
---
lib/utils/fdt/fdt_domain.c | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/lib/utils/fdt/fdt_domain.c b/lib/utils/fdt/fdt_domain.c
index 61627db3..0849c4d0 100644
--- a/lib/utils/fdt/fdt_domain.c
+++ b/lib/utils/fdt/fdt_domain.c
@@ -469,6 +469,21 @@ static int __fdt_parse_domain(const void *fdt, int domain_offset, void *opaque)
}
dom->next_mode = val32;
+ /* Read "next-wid" DT property */
+ val = fdt_getprop(fdt, domain_offset, "next-wid", &len);
+ if (val && len == sizeof(fdt32_t)) {
+ dom->next_wid = fdt32_to_cpu(val[0]);
+ dom->has_next_wid = true;
+ }
+
+ /* Read "next-widlist" DT property */
+ val = fdt_getprop(fdt, domain_offset, "next-widlist", &len);
+ if (val && (len == (2 * sizeof(fdt32_t)))) {
+ val64 = fdt32_to_cpu(val[0]);
+ val64 = (val64 << 32) | fdt32_to_cpu(val[1]);
+ dom->next_widlist = val64;
+ }
+
/* Read "system-reset-allowed" DT property */
if (fdt_get_property(fdt, domain_offset,
"system-reset-allowed", NULL))
--
2.43.7
More information about the opensbi
mailing list