RISC-V: KVM: provide UAPI for host SATP mode
authorDaniel Henrique Barboza <dbarboza@ventanamicro.com>
Fri, 28 Jul 2023 21:01:22 +0000 (18:01 -0300)
committerAnup Patel <anup@brainfault.org>
Tue, 8 Aug 2023 11:55:40 +0000 (17:25 +0530)
commit2776421e6839b67c34261861b169b7ee737b4c00
tree7a816fa478f769c35eff8d03ef825e745d520c59
parentd2064d4a6e3a565879da196947fb35cc7b1f3256
RISC-V: KVM: provide UAPI for host SATP mode

KVM userspaces need to be aware of the host SATP to allow them to
advertise it back to the guest OS.

Since this information is used to build the guest FDT we can't wait for
the SATP reg to be readable. We just need to read the SATP mode, thus
we can use the existing 'satp_mode' global that represents the SATP reg
with MODE set and both ASID and PPN cleared. E.g. for a 32 bit host
running with sv32 satp_mode is 0x80000000, for a 64 bit host running
sv57 satp_mode is 0xa000000000000000, and so on.

Add a new userspace virtual config register 'satp_mode' to allow
userspace to read the current SATP mode the host is using with
GET_ONE_REG API before spinning the vcpu.

'satp_mode' can't be changed via KVM, so SET_ONE_REG is allowed as long
as userspace writes the existing 'satp_mode'.

Signed-off-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com>
Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
Signed-off-by: Anup Patel <anup@brainfault.org>
arch/riscv/include/asm/csr.h
arch/riscv/include/uapi/asm/kvm.h
arch/riscv/kvm/vcpu_onereg.c