]> git.baikalelectronics.ru Git - kernel.git/commit
KVM: arm64: Trap host SMCs in protected mode
authorDavid Brazdil <dbrazdil@google.com>
Wed, 2 Dec 2020 18:41:21 +0000 (18:41 +0000)
committerMarc Zyngier <maz@kernel.org>
Fri, 4 Dec 2020 10:08:36 +0000 (10:08 +0000)
commit42d09b949e62db69972450900983b82b90b1b71b
tree80d2c8db84a6814f364ef9d785e4a413237e2773
parentd1eab6e42c69e78cd28deceafc881b057f63180a
KVM: arm64: Trap host SMCs in protected mode

While protected KVM is installed, start trapping all host SMCs.
For now these are simply forwarded to EL3, except PSCI
CPU_ON/CPU_SUSPEND/SYSTEM_SUSPEND which are intercepted and the
hypervisor installed on newly booted cores.

Create new constant HCR_HOST_NVHE_PROTECTED_FLAGS with the new set of HCR
flags to use while the nVHE vector is installed when the kernel was
booted with the protected flag enabled. Switch back to the default HCR
flags when switching back to the stub vector.

Signed-off-by: David Brazdil <dbrazdil@google.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20201202184122.26046-26-dbrazdil@google.com
arch/arm64/include/asm/kvm_arm.h
arch/arm64/kvm/hyp/nvhe/hyp-init.S
arch/arm64/kvm/hyp/nvhe/switch.c