[PATCH] lib: sbi: sbi_mpxy_set_shmem adds parameter check
Xiang W
wxjstz at 126.com
Wed Mar 19 05:37:07 PDT 2025
Shared memory needs to be accessed in M-Mode, and the high address of
physical memory should be 0
Signed-off-by: Xiang W <wxjstz at 126.com>
---
lib/sbi/sbi_mpxy.c | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/lib/sbi/sbi_mpxy.c b/lib/sbi/sbi_mpxy.c
index c5d9d1bb..7d4d26ab 100644
--- a/lib/sbi/sbi_mpxy.c
+++ b/lib/sbi/sbi_mpxy.c
@@ -287,6 +287,20 @@ int sbi_mpxy_set_shmem(unsigned long shmem_phys_lo,
if (shmem_phys_lo & ~PAGE_MASK)
return SBI_ERR_INVALID_PARAM;
+ /*
+ * On RV32, the M-mode can only access the first 4GB of
+ * the physical address space because M-mode does not have
+ * MMU to access full 34-bit physical address space.
+ * So fail if the upper 32 bits of the physical address
+ * is non-zero on RV32.
+ *
+ * On RV64, kernel sets upper 64bit address part to zero.
+ * So fail if the upper 64bit of the physical address
+ * is non-zero on RV64.
+ */
+ if (shmem_phys_hi)
+ return SBI_ERR_INVALID_PARAM;
+
if (!sbi_domain_check_addr_range(sbi_domain_thishart_ptr(),
SHMEM_PHYS_ADDR(shmem_phys_hi, shmem_phys_lo),
mpxy_shmem_size, PRV_S,
--
2.47.2
More information about the opensbi
mailing list