aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRadim Krčmář <rkrcmar@ventanamicro.com>2025-04-29 16:25:45 +0200
committerAnup Patel <anup@brainfault.org>2025-04-30 10:14:26 +0530
commit009f77a9f06bcb5a3a6252b3333171adb8c84512 (patch)
treeb4c09454bdc1f7a264f382b864eab96987bc09b6
parent65e8be4fe85e0e4410026a86256682a314ddf173 (diff)
downloadopensbi-009f77a9f06bcb5a3a6252b3333171adb8c84512.zip
opensbi-009f77a9f06bcb5a3a6252b3333171adb8c84512.tar.gz
opensbi-009f77a9f06bcb5a3a6252b3333171adb8c84512.tar.bz2
lib: sbi_hart: reset hstatus
hstatus.HU must be cleared, because U-mode could otherwise use the HLS/HSV instructions. This would allow U-mode to read physical memory directly if vgatp and vsatp was 0. The remaining fields don't seem like a security vulnerability now, but clearing the whole CSR is not an issue, so do that be safe. Reviewed-by: Anup Patel <anup@brainfault.org> Signed-off-by: Radim Krčmář <rkrcmar@ventanamicro.com> Link: https://lore.kernel.org/r/20250429142549.3673976-5-rkrcmar@ventanamicro.com Signed-off-by: Anup Patel <anup@brainfault.org>
-rw-r--r--lib/sbi/sbi_hart.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/lib/sbi/sbi_hart.c b/lib/sbi/sbi_hart.c
index 26d746d..5ea7328 100644
--- a/lib/sbi/sbi_hart.c
+++ b/lib/sbi/sbi_hart.c
@@ -85,6 +85,9 @@ static void mstatus_init(struct sbi_scratch *scratch)
#endif
}
+ if (misa_extension('H'))
+ csr_write(CSR_HSTATUS, 0);
+
if (sbi_hart_has_extension(scratch, SBI_HART_EXT_SMSTATEEN)) {
mstateen_val = csr_read64(CSR_MSTATEEN0);
mstateen_val |= SMSTATEEN_STATEN;