lib: sbi_trap: Set hstatus.GVA when going to HS-mode
authorVivian Wang <dramforever@live.com>
Thu, 4 Aug 2022 14:32:31 +0000 (22:32 +0800)
committerAnup Patel <anup@brainfault.org>
Mon, 22 Aug 2022 03:20:23 +0000 (08:50 +0530)
The privileged spec specifies that on a trap to HS-mode, hstatus.GVA
should be set to 1 if stval is written with a guest virtual address, and
to 0 otherwise. Implement this by setting hstatus.GVA to trap->gva when
redirecting traps to HS-mode.

Signed-off-by: Vivian Wang <dramforever@live.com>
Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
Reviewed-by: Anup Patel <anup@brainfault.org>
lib/sbi/sbi_trap.c

index 1cf2e6f..925840f 100644 (file)
@@ -128,6 +128,8 @@ int sbi_trap_redirect(struct sbi_trap_regs *regs,
                }
                hstatus &= ~HSTATUS_SPV;
                hstatus |= (prev_virt) ? HSTATUS_SPV : 0;
+               hstatus &= ~HSTATUS_GVA;
+               hstatus |= (trap->gva) ? HSTATUS_GVA : 0;
                csr_write(CSR_HSTATUS, hstatus);
                csr_write(CSR_HTVAL, trap->tval2);
                csr_write(CSR_HTINST, trap->tinst);