arm/arm64: KVM: Add PSCI version selection API
authorMarc Zyngier <marc.zyngier@arm.com>
Sun, 21 Jan 2018 16:42:56 +0000 (16:42 +0000)
committerMarc Zyngier <marc.zyngier@arm.com>
Fri, 20 Apr 2018 15:32:23 +0000 (16:32 +0100)
commit85bd0ba1ff9875798fad94218b627ea9f768f3c3
tree7a1d8741a980a8d8d0a235c1784b2121634a9265
parentbf9a41377d14f565764022470e14aae72559589a
arm/arm64: KVM: Add PSCI version selection API

Although we've implemented PSCI 0.1, 0.2 and 1.0, we expose either 0.1
or 1.0 to a guest, defaulting to the latest version of the PSCI
implementation that is compatible with the requested version. This is
no different from doing a firmware upgrade on KVM.

But in order to give a chance to hypothetical badly implemented guests
that would have a fit by discovering something other than PSCI 0.2,
let's provide a new API that allows userspace to pick one particular
version of the API.

This is implemented as a new class of "firmware" registers, where
we expose the PSCI version. This allows the PSCI version to be
save/restored as part of a guest migration, and also set to
any supported version if the guest requires it.

Cc: stable@vger.kernel.org #4.16
Reviewed-by: Christoffer Dall <cdall@kernel.org>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Documentation/virtual/kvm/api.txt
Documentation/virtual/kvm/arm/psci.txt [new file with mode: 0644]
arch/arm/include/asm/kvm_host.h
arch/arm/include/uapi/asm/kvm.h
arch/arm/kvm/guest.c
arch/arm64/include/asm/kvm_host.h
arch/arm64/include/uapi/asm/kvm.h
arch/arm64/kvm/guest.c
include/kvm/arm_psci.h
virt/kvm/arm/psci.c