The KVM_EXIT_SYSTEM_EVENT exit reason was added to define
architecture independent system-wide events for a Guest.

Currently, it is used by in-kernel PSCI-0.2 emulation of
KVM ARM/ARM64 to inform user space about PSCI SYSTEM_OFF
or PSCI SYSTEM_RESET request.

For now, we simply treat all system-wide guest events as
shutdown request in KVMTOOL.

Signed-off-by: Pranavkumar Sawargaonkar <pranavku...@linaro.org>
Signed-off-by: Anup Patel <anup.pa...@linaro.org>
---
 tools/kvm/kvm-cpu.c |   19 +++++++++++++++++++
 1 file changed, 19 insertions(+)

diff --git a/tools/kvm/kvm-cpu.c b/tools/kvm/kvm-cpu.c
index ee0a8ec..6d01192 100644
--- a/tools/kvm/kvm-cpu.c
+++ b/tools/kvm/kvm-cpu.c
@@ -160,6 +160,25 @@ int kvm_cpu__start(struct kvm_cpu *cpu)
                        goto exit_kvm;
                case KVM_EXIT_SHUTDOWN:
                        goto exit_kvm;
+               case KVM_EXIT_SYSTEM_EVENT:
+                       /*
+                        * Print the type of system event and
+                        * treat all system events as shutdown request.
+                        */
+                       switch (cpu->kvm_run->system_event.type) {
+                       case KVM_SYSTEM_EVENT_SHUTDOWN:
+                               printf("  # Info: shutdown system event\n");
+                               break;
+                       case KVM_SYSTEM_EVENT_RESET:
+                               printf("  # Info: reset system event\n");
+                               break;
+                       default:
+                               printf("  # Warning: unknown system event 
type=%d\n",
+                                      cpu->kvm_run->system_event.type);
+                               break;
+                       };
+                       printf("  # Info: exiting KVMTOOL\n");
+                       goto exit_kvm;
                default: {
                        bool ret;
 
-- 
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to