diff options
author | Bin Meng <bmeng@tinylab.org> | 2022-12-11 09:54:24 +0300 |
---|---|---|
committer | Anup Patel <anup@brainfault.org> | 2022-12-17 06:33:30 +0300 |
commit | 9a2eeb4aaeac9102a7db3676035d83394784c88b (patch) | |
tree | a1969ea5d42c251b3d17890e9e74fb537b7da09d /platform | |
parent | fabbc006687a0fddeabb7a3effabb3a8e1c81c48 (diff) | |
download | opensbi-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.c | 5 |
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); } /* |