From 43ad2fb0bcd61cbb6dace01e55f56f00a685a984 Mon Sep 17 00:00:00 2001 From: Donald Dutile Date: Thu, 15 Jul 2010 14:56:49 -0400 Subject: [PATCH] --- yaml --- r: 204775 b: refs/heads/master c: f09f6d194d85043e0eb105a577e7ad6d8170ab66 h: refs/heads/master i: 204773: cf155fd55226f3ff052c5367c225f69d184b908d 204771: a880453de8a2393834c72afc8e2b436a942fa89a 204767: c0e3599724c752fce84605fa7873592198b5c73c v: v3 --- [refs] | 2 +- trunk/arch/x86/xen/enlighten.c | 20 ++++++++++++++++++++ trunk/arch/x86/xen/setup.c | 2 ++ trunk/arch/x86/xen/xen-ops.h | 2 ++ 4 files changed, 25 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index f6d4f61d5bee..aa6e0b69d1ae 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c06ee78d73fd24e8d8a65f16380f6a0551107e1b +refs/heads/master: f09f6d194d85043e0eb105a577e7ad6d8170ab66 diff --git a/trunk/arch/x86/xen/enlighten.c b/trunk/arch/x86/xen/enlighten.c index 90a3e8026767..d99522e8f033 100644 --- a/trunk/arch/x86/xen/enlighten.c +++ b/trunk/arch/x86/xen/enlighten.c @@ -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, diff --git a/trunk/arch/x86/xen/setup.c b/trunk/arch/x86/xen/setup.c index 9deb6bab6c78..328b00305426 100644 --- a/trunk/arch/x86/xen/setup.c +++ b/trunk/arch/x86/xen/setup.c @@ -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); diff --git a/trunk/arch/x86/xen/xen-ops.h b/trunk/arch/x86/xen/xen-ops.h index f9153a300bce..00d59d608edf 100644 --- a/trunk/arch/x86/xen/xen-ops.h +++ b/trunk/arch/x86/xen/xen-ops.h @@ -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 */