KVM: arm64: Ensure that SME controls are disabled in protected mode
authorFuad Tabba <tabba@google.com>
Mon, 3 Jun 2024 12:28:51 +0000 (13:28 +0100)
committerMarc Zyngier <maz@kernel.org>
Tue, 4 Jun 2024 14:06:33 +0000 (15:06 +0100)
commitafb91f5f8ad7af172d993a34fde1947892408f53
treedeeee773464a6957b597dc5abe111564ba476746
parenta69283ae1db8dd416870d931caa9e2d3d2c1cd8b
KVM: arm64: Ensure that SME controls are disabled in protected mode

KVM (and pKVM) do not support SME guests. Therefore KVM ensures
that the host's SME state is flushed and that SME controls for
enabling access to ZA storage and for streaming are disabled.

pKVM needs to protect against a buggy/malicious host. Ensure that
it wouldn't run a guest when protected mode is enabled should any
of the SME controls be enabled.

Signed-off-by: Fuad Tabba <tabba@google.com>
Link: https://lore.kernel.org/r/20240603122852.3923848-10-tabba@google.com
Signed-off-by: Marc Zyngier <maz@kernel.org>
arch/arm64/kvm/fpsimd.c
arch/arm64/kvm/hyp/nvhe/hyp-main.c