[PATCH 02/10] platform: rzfive: Call andes_pma_setup_regions() only during cold boot

Samuel Holland samuel.holland at sifive.com
Tue Mar 25 16:43:25 PDT 2025


This function accesses the FDT blob, which means it is only valid to
call during cold boot, before a lower privilege level has an opportunity
to clobber that memory.

Signed-off-by: Samuel Holland <samuel.holland at sifive.com>
---

 platform/generic/renesas/rzfive/rzfive.c | 12 ++++++++++--
 1 file changed, 10 insertions(+), 2 deletions(-)

diff --git a/platform/generic/renesas/rzfive/rzfive.c b/platform/generic/renesas/rzfive/rzfive.c
index 59084c41..db523088 100644
--- a/platform/generic/renesas/rzfive/rzfive.c
+++ b/platform/generic/renesas/rzfive/rzfive.c
@@ -27,8 +27,16 @@ static const struct andes_pma_region renesas_rzfive_pma_regions[] = {
 static int renesas_rzfive_final_init(bool cold_boot, void *fdt,
 				     const struct fdt_match *match)
 {
-	return andes_pma_setup_regions(fdt, renesas_rzfive_pma_regions,
-				       array_size(renesas_rzfive_pma_regions));
+	int rc;
+
+	if (cold_boot) {
+		rc = andes_pma_setup_regions(fdt, renesas_rzfive_pma_regions,
+					     array_size(renesas_rzfive_pma_regions));
+		if (rc)
+			return rc;
+	}
+
+	return 0;
 }
 
 static int renesas_rzfive_early_init(bool cold_boot, const void *fdt,
-- 
2.47.2




More information about the opensbi mailing list