summaryrefslogtreecommitdiff
path: root/platform
diff options
context:
space:
mode:
authorBin Meng <bmeng@tinylab.org>2022-12-11 09:54:24 +0300
committerAnup Patel <anup@brainfault.org>2022-12-17 06:33:30 +0300
commit9a2eeb4aaeac9102a7db3676035d83394784c88b (patch)
treea1969ea5d42c251b3d17890e9e74fb537b7da09d /platform
parentfabbc006687a0fddeabb7a3effabb3a8e1c81c48 (diff)
downloadopensbi-9a2eeb4aaeac9102a7db3676035d83394784c88b.tar.xz
lib: utils/irqchip: plic: Ensure no out-of-bound access in context save/restore helpers
Currently the context save/restore helpers writes/reads the provided array using an index whose maximum value is determined by PLIC, which potentially may disagree with the caller to these helpers. Add a parameter to ask the caller to provide the size limit of the array to ensure no out-of-bound access happens. Signed-off-by: Bin Meng <bmeng@tinylab.org> Reviewed-by: Anup Patel <anup@brainfault.org>
Diffstat (limited to 'platform')
-rw-r--r--platform/generic/allwinner/sun20i-d1.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/platform/generic/allwinner/sun20i-d1.c b/platform/generic/allwinner/sun20i-d1.c
index 1f27575..1da9e5b 100644
--- a/platform/generic/allwinner/sun20i-d1.c
+++ b/platform/generic/allwinner/sun20i-d1.c
@@ -78,7 +78,7 @@ static u32 plic_threshold;
static void sun20i_d1_plic_save(void)
{
- fdt_plic_context_save(true, plic_sie, &plic_threshold);
+ fdt_plic_context_save(true, plic_sie, &plic_threshold, PLIC_IE_WORDS);
fdt_plic_priority_save(plic_priority, PLIC_SOURCES);
}
@@ -86,7 +86,8 @@ static void sun20i_d1_plic_restore(void)
{
thead_plic_restore();
fdt_plic_priority_restore(plic_priority, PLIC_SOURCES);
- fdt_plic_context_restore(true, plic_sie, plic_threshold);
+ fdt_plic_context_restore(true, plic_sie, plic_threshold,
+ PLIC_IE_WORDS);
}
/*