i386/xen: implement HYPERVISOR_sched_op, SCHEDOP_shutdown
commit79b7067dc6acec07d93407dd870268a5cd68924d
authorJoao Martins <joao.m.martins@oracle.com>
Fri, 20 Jul 2018 19:19:05 +0000 (20 15:19 -0400)
committerDavid Woodhouse <dwmw@amazon.co.uk>
Wed, 1 Mar 2023 08:22:49 +0000 (1 08:22 +0000)
treed2e15a11db181921df08a61145f430cd49cdc873
parentbedcc1392481e2528d9b470a9b21512a923a3b75
i386/xen: implement HYPERVISOR_sched_op, SCHEDOP_shutdown

It allows to shutdown itself via hypercall with any of the 3 reasons:
  1) self-reboot
  2) shutdown
  3) crash

Implementing SCHEDOP_shutdown sub op let us handle crashes gracefully rather
than leading to triple faults if it remains unimplemented.

In addition, the SHUTDOWN_soft_reset reason is used for kexec, to reset
Xen shared pages and other enlightenments and leave a clean slate for the
new kernel without the hypervisor helpfully writing information at
unexpected addresses.

Signed-off-by: Joao Martins <joao.m.martins@oracle.com>
[dwmw2: Ditch sched_op_compat which was never available for HVM guests,
        Add SCHEDOP_soft_reset]
Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Paul Durrant <paul@xen.org>
include/sysemu/kvm_xen.h
target/i386/kvm/trace-events
target/i386/kvm/xen-emu.c