Xen: register panic notifier to take crashes of xen guests on panic
authorDonald Dutile <ddutile@redhat.com>
Thu, 15 Jul 2010 18:56:49 +0000 (14:56 -0400)
committerJeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
Wed, 4 Aug 2010 21:47:31 +0000 (14:47 -0700)
Register a panic notifier so that when the guest crashes it can shut
down the domain and indicate it was a crash to the host.

Signed-off-by: Donald Dutile <ddutile@redhat.com>
Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
arch/x86/xen/enlighten.c
arch/x86/xen/setup.c
arch/x86/xen/xen-ops.h

index 90a3e802676785de84bb296816c23dd61e314863..d99522e8f033c077288a17ed44197d09fc569eac 100644 (file)
@@ -1040,6 +1040,26 @@ static void xen_crash_shutdown(struct pt_regs *regs)
        xen_reboot(SHUTDOWN_crash);
 }
 
+static int
+xen_panic_event(struct notifier_block *this, unsigned long event, void *ptr)
+{
+       struct sched_shutdown r = { .reason = SHUTDOWN_crash};
+
+       if (HYPERVISOR_sched_op(SCHEDOP_shutdown, &r))
+               BUG();
+       return NOTIFY_DONE;
+}
+
+static struct notifier_block xen_panic_block = {
+       .notifier_call= xen_panic_event,
+};
+
+int xen_panic_handler_init(void)
+{
+       atomic_notifier_chain_register(&panic_notifier_list, &xen_panic_block);
+       return 0;
+}
+
 static const struct machine_ops __initdata xen_machine_ops = {
        .restart = xen_restart,
        .halt = xen_machine_halt,
index 9deb6bab6c78470e34b19bcf548ba6869a9dd1d5..328b003054267d074610fdce51c39b063fae48e6 100644 (file)
@@ -226,6 +226,8 @@ void __init xen_arch_setup(void)
        struct physdev_set_iopl set_iopl;
        int rc;
 
+       xen_panic_handler_init();
+
        HYPERVISOR_vm_assist(VMASST_CMD_enable, VMASST_TYPE_4gb_segments);
        HYPERVISOR_vm_assist(VMASST_CMD_enable, VMASST_TYPE_writable_pagetables);
 
index f9153a300bcee998e1f78f95a202cc9036df79ca..00d59d608edf20ad6faa25f2e60537faca969374 100644 (file)
@@ -101,4 +101,6 @@ void xen_sysret32(void);
 void xen_sysret64(void);
 void xen_adjust_exception_frame(void);
 
+extern int xen_panic_handler_init(void);
+
 #endif /* XEN_OPS_H */