[PATCH] lib: sbi: Fix bug in sbi_ecall_rfence that misses checking
Atish Patra
atishp at atishpatra.org
Mon Aug 16 17:22:05 PDT 2021
On Fri, Aug 13, 2021 at 5:34 AM Dong Du <Dd_nirvana at sjtu.edu.cn> wrote:
>
> In sbi_ecall_rfence_handler, it will compare the funcid with REMOTE_HFENCE_GVMA and
> REMOTE_HFENCE_VVMA_ASID.
> And then check whether the misa includes H-extension.
> This checking is incomplete which misses REMOTE_HFENCE_GVMA_VMID and REMOTE_HFENCE_VVMA.
> Fix the issue by updating the checking range.
>
> Signed-off-by: Dong Du <Dd_nirvana at sjtu.edu.cn>
> ---
> lib/sbi/sbi_ecall_replace.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/lib/sbi/sbi_ecall_replace.c b/lib/sbi/sbi_ecall_replace.c
> index a7935d9..5d24565 100644
> --- a/lib/sbi/sbi_ecall_replace.c
> +++ b/lib/sbi/sbi_ecall_replace.c
> @@ -54,8 +54,8 @@ static int sbi_ecall_rfence_handler(unsigned long extid, unsigned long funcid,
> struct sbi_tlb_info tlb_info;
> u32 source_hart = current_hartid();
>
> - if (funcid >= SBI_EXT_RFENCE_REMOTE_HFENCE_GVMA &&
> - funcid <= SBI_EXT_RFENCE_REMOTE_HFENCE_VVMA_ASID)
> + if (funcid >= SBI_EXT_RFENCE_REMOTE_HFENCE_GVMA_VMID &&
> + funcid <= SBI_EXT_RFENCE_REMOTE_HFENCE_VVMA)
> if (!misa_extension('H'))
> return SBI_ENOTSUPP;
>
> --
> 2.31.1
>
>
> --
> opensbi mailing list
> opensbi at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/opensbi
Reviewed-by: Atish Patra <atish.patra at wdc.com>
--
Regards,
Atish
More information about the opensbi
mailing list