]> 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)
commit400ddbe8bdfad926b15f21c83372c393a73e7e49
tree80d2c8db84a6814f364ef9d785e4a413237e2773
parent6cdb94b65708c29eff5ec74b4f9a0d93d948c576
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