[PATCH v2 8/8] lib: sbi_hart: properly reset Ssstateen
Radim Krčmář
rkrcmar at ventanamicro.com
Tue Apr 29 07:25:50 PDT 2025
sstateen* and hstateen* CSRs must be zeroed by M-mode if the mstateen*
registers are missing, to avoid security issues.
Reviewed-by: Anup Patel <anup at brainfault.org>
Signed-off-by: Radim Krčmář <rkrcmar at ventanamicro.com>
---
v2:
* Remove pointless Smstateen check. [Anup]
* Add Reviewed-by [Anup]
---
lib/sbi/sbi_hart.c | 15 ++++++++++++---
1 file changed, 12 insertions(+), 3 deletions(-)
diff --git a/lib/sbi/sbi_hart.c b/lib/sbi/sbi_hart.c
index 8dc61d6ff230..fc4925b57625 100644
--- a/lib/sbi/sbi_hart.c
+++ b/lib/sbi/sbi_hart.c
@@ -114,12 +114,21 @@ static void mstatus_init(struct sbi_scratch *scratch)
csr_write64(CSR_MSTATEEN1, SMSTATEEN_STATEN);
csr_write64(CSR_MSTATEEN2, SMSTATEEN_STATEN);
csr_write64(CSR_MSTATEEN3, SMSTATEEN_STATEN);
+ }
- if (misa_extension('S'))
+ if (sbi_hart_has_extension(scratch, SBI_HART_EXT_SSSTATEEN)) {
+ if (misa_extension('S')) {
csr_write(CSR_SSTATEEN0, 0);
-
- if (misa_extension('H'))
+ csr_write(CSR_SSTATEEN1, 0);
+ csr_write(CSR_SSTATEEN2, 0);
+ csr_write(CSR_SSTATEEN3, 0);
+ }
+ if (misa_extension('H')) {
csr_write64(CSR_HSTATEEN0, (uint64_t)0);
+ csr_write64(CSR_HSTATEEN1, (uint64_t)0);
+ csr_write64(CSR_HSTATEEN2, (uint64_t)0);
+ csr_write64(CSR_HSTATEEN3, (uint64_t)0);
+ }
}
if (sbi_hart_priv_version(scratch) >= SBI_HART_PRIV_VER_1_12) {
--
2.48.1
More information about the opensbi
mailing list