KVM: arm64: nv: Introduce nested virtualization VCPU feature
authorChristoffer Dall <christoffer.dall@arm.com>
Thu, 9 Feb 2023 17:58:05 +0000 (17:58 +0000)
committerOliver Upton <oliver.upton@linux.dev>
Sat, 11 Feb 2023 09:16:11 +0000 (09:16 +0000)
commit89b0e7de3451a17f23bc1c39bc40eee1811f1669
tree3e8653407c25c04c0b441919cf2d7703d63c9473
parent8531bd63a8dc6c83fef2e1b7cbfd6f1a50bf87db
KVM: arm64: nv: Introduce nested virtualization VCPU feature

Introduce the feature bit and a primitive that checks if the feature is
set behind a static key check based on the cpus_have_const_cap check.

Checking vcpu_has_nv() on systems without nested virt enabled
should have negligible overhead.

We don't yet allow userspace to actually set this feature.

Reviewed-by: Ganapatrao Kulkarni <gankulkarni@os.amperecomputing.com>
Reviewed-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: Christoffer Dall <christoffer.dall@arm.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20230209175820.1939006-4-maz@kernel.org
Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
arch/arm64/include/asm/kvm_nested.h [new file with mode: 0644]
arch/arm64/include/uapi/asm/kvm.h