KVM: arm64: Correctly handle ACCDATA_EL1 traps
authorMarc Zyngier <maz@kernel.org>
Tue, 15 Aug 2023 18:38:44 +0000 (19:38 +0100)
committerMarc Zyngier <maz@kernel.org>
Thu, 17 Aug 2023 09:00:27 +0000 (10:00 +0100)
commit484f86824a3d94c6d9412618dd70b1d5923fff6f
tree5d1313be0a188916d30ac451183f900fef7405be
parentb206a708cbfb352f2191089678ab595d24563011
KVM: arm64: Correctly handle ACCDATA_EL1 traps

As we blindly reset some HFGxTR_EL2 bits to 0, we also randomly trap
unsuspecting sysregs that have their trap bits with a negative
polarity.

ACCDATA_EL1 is one such register that can be accessed by the guest,
causing a splat on the host as we don't have a proper handler for
it.

Adding such handler addresses the issue, though there are a number
of other registers missing as the current architecture documentation
doesn't describe them yet.

Reviewed-by: Eric Auger <eric.auger@redhat.com>
Reviewed-by: Miguel Luis <miguel.luis@oracle.com>
Reviewed-by: Jing Zhang <jingzhangos@google.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20230815183903.2735724-11-maz@kernel.org
arch/arm64/include/asm/sysreg.h
arch/arm64/kvm/sys_regs.c