]> 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)
commitb93c17c4185bf6b50f2f0b332afb4abe8b766a7a
tree80d2c8db84a6814f364ef9d785e4a413237e2773
parentfa8c3d65538aa11bb117cbf872400d5caa7f340b
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