KVM: arm64: Destroy mpidr_data for 'late' vCPU creation
authorOliver Upton <oliver.upton@linux.dev>
Wed, 8 May 2024 07:19:52 +0000 (07:19 +0000)
committerMarc Zyngier <maz@kernel.org>
Wed, 8 May 2024 15:39:41 +0000 (16:39 +0100)
commitce5d2448eb8fe83aed331db53a08612286a137dd
tree0b25b657a0a6d3de49234c1ff44387e23f80c365
parent5053c3f0519cd4c746577e3a6a7756f7c04b03dd
KVM: arm64: Destroy mpidr_data for 'late' vCPU creation

A particularly annoying userspace could create a vCPU after KVM has
computed mpidr_data for the VM, either by racing against VGIC
initialization or having a userspace irqchip.

In any case, this means mpidr_data no longer fully describes the VM, and
attempts to find the new vCPU with kvm_mpidr_to_vcpu() will fail. The
fix is to discard mpidr_data altogether, as it is only a performance
optimization and not required for correctness. In all likelihood KVM
will recompute the mappings when KVM_RUN is called on the new vCPU.

Note that reads of mpidr_data are not guarded by a lock; promote to RCU
to cope with the possibility of mpidr_data being invalidated at runtime.

Fixes: 54a8006d0b49 ("KVM: arm64: Fast-track kvm_mpidr_to_vcpu() when mpidr_data is available")
Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
Link: https://lore.kernel.org/r/20240508071952.2035422-1-oliver.upton@linux.dev
Signed-off-by: Marc Zyngier <maz@kernel.org>
arch/arm64/kvm/arm.c