KVM: arm64: Fix bad dereference on MTE-enabled systems
authorRyan Roberts <ryan.roberts@arm.com>
Thu, 27 Oct 2022 12:09:45 +0000 (13:09 +0100)
committerMarc Zyngier <maz@kernel.org>
Thu, 27 Oct 2022 18:49:40 +0000 (19:49 +0100)
commitb6bcdc9f6b8321e4471ff45413b6410e16762a8d
treef67bb883abd47c37f7a9d1914395469c043e01ad
parent6853a71726b6f5930b4450889faf02e8f1cfe35c
KVM: arm64: Fix bad dereference on MTE-enabled systems

enter_exception64() performs an MTE check, which involves dereferencing
vcpu->kvm. While vcpu has already been fixed up to be a HYP VA pointer,
kvm is still a pointer in the kernel VA space.

This only affects nVHE configurations with MTE enabled, as in other
cases, the pointer is either valid (VHE) or not dereferenced (!MTE).

Fix this by first converting kvm to a HYP VA pointer.

Fixes: ea7fc1bb1cd1 ("KVM: arm64: Introduce MTE VM feature")
Signed-off-by: Ryan Roberts <ryan.roberts@arm.com>
Reviewed-by: Steven Price <steven.price@arm.com>
[maz: commit message tidy-up]
Signed-off-by: Marc Zyngier <maz@kernel.org>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/20221027120945.29679-1-ryan.roberts@arm.com
arch/arm64/kvm/hyp/exception.c