sev/i386: Don't allow a system reset under an SEV-ES guest
commit92a5199b29f6519aa5f774f4b96dc41954f641d1
authorTom Lendacky <thomas.lendacky@amd.com>
Tue, 26 Jan 2021 17:36:47 +0000 (26 11:36 -0600)
committerPaolo Bonzini <pbonzini@redhat.com>
Tue, 16 Feb 2021 16:15:39 +0000 (16 17:15 +0100)
treed6346db204e09ea7c5b2546dded9bb7ae457aa88
parentb2f73a0784b7a5eae2022ccf3293792bd008cc64
sev/i386: Don't allow a system reset under an SEV-ES guest

An SEV-ES guest does not allow register state to be altered once it has
been measured. When an SEV-ES guest issues a reboot command, Qemu will
reset the vCPU state and resume the guest. This will cause failures under
SEV-ES. Prevent that from occuring by introducing an arch-specific
callback that returns a boolean indicating whether vCPUs are resettable.

Cc: Peter Maydell <peter.maydell@linaro.org>
Cc: Aurelien Jarno <aurelien@aurel32.net>
Cc: Jiaxun Yang <jiaxun.yang@flygoat.com>
Cc: Aleksandar Rikalo <aleksandar.rikalo@syrmia.com>
Cc: David Gibson <david@gibson.dropbear.id.au>
Cc: David Hildenbrand <david@redhat.com>
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
Reviewed-by: Venu Busireddy <venu.busireddy@oracle.com>
Message-Id: <1ac39c441b9a3e970e9556e1cc29d0a0814de6fd.1611682609.git.thomas.lendacky@amd.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
accel/kvm/kvm-all.c
include/sysemu/cpus.h
include/sysemu/hw_accel.h
include/sysemu/kvm.h
softmmu/cpus.c
softmmu/runstate.c
target/arm/kvm.c
target/i386/kvm/kvm.c
target/mips/kvm.c
target/ppc/kvm.c
target/s390x/kvm.c