From mboxrd@z Thu Jan 1 00:00:00 1970 From: Andrew Cooper Subject: x86/nmi: Fix deadlock in unknown_nmi_error() Date: Fri, 8 Jun 2012 19:56:25 +0100 Message-ID: <4FD24AD9.3010607@citrix.com> Mime-Version: 1.0 Content-Type: multipart/mixed; boundary="------------060602030301090907040708" Return-path: List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xen.org Errors-To: xen-devel-bounces@lists.xen.org To: "xen-devel@lists.xen.org" Cc: Keir Fraser , Jan Beulich List-Id: xen-devel@lists.xenproject.org --------------060602030301090907040708 Content-Type: text/plain; charset="ISO-8859-1" Content-Transfer-Encoding: 7bit x86/nmi: Fix deadlock in unknown_nmi_error() Additionally, correct the text description to reflect what is being done, and make use of fatal_trap() in preference to kexec_crash() in case an unknown NMI occurs before a kdump kernel has been loaded. Signed-off-by: Andrew Cooper diff -r 32034d1914a6 -r 996f7fe3c3b8 xen/arch/x86/traps.c --- a/xen/arch/x86/traps.c +++ b/xen/arch/x86/traps.c @@ -3293,7 +3293,7 @@ static void io_check_error(struct cpu_us outb((inb(0x61) & 0x07) | 0x00, 0x61); /* enable IOCK */ } -static void unknown_nmi_error(unsigned char reason) +static void unknown_nmi_error(struct cpu_user_regs *regs, unsigned char reason) { switch ( opt_nmi[0] ) { @@ -3302,10 +3302,10 @@ static void unknown_nmi_error(unsigned c case 'i': /* 'ignore' */ break; default: /* 'fatal' */ + console_force_unlock(); printk("Uhhuh. NMI received for unknown reason %02x.\n", reason); - printk("Dazed and confused, but trying to continue\n"); printk("Do you have a strange power saving mode enabled?\n"); - kexec_crash(); + fatal_trap(TRAP_nmi, regs); } } @@ -3338,7 +3338,7 @@ void do_nmi(struct cpu_user_regs *regs) else if ( reason & 0x40 ) io_check_error(regs); else if ( !nmi_watchdog ) - unknown_nmi_error((unsigned char)(reason&0xff)); + unknown_nmi_error(regs, (unsigned char)(reason&0xff)); } } -- Andrew Cooper - Dom0 Kernel Engineer, Citrix XenServer T: +44 (0)1223 225 900, http://www.citrix.com --------------060602030301090907040708 Content-Type: text/x-patch; name="nmi-fix-deadlock.patch" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="nmi-fix-deadlock.patch" # HG changeset patch # Parent 32034d1914a607d7b6f1f060352b4cac973600f8 x86/nmi: Fix deadlock in unknown_nmi_error() Additionally, correct the text description to reflect what is being done, and make use of fatal_trap() in preference to kexec_crash() in case an unknown NMI occurs before a kdump kernel has been loaded. Signed-off-by: Andrew Cooper diff -r 32034d1914a6 xen/arch/x86/traps.c --- a/xen/arch/x86/traps.c +++ b/xen/arch/x86/traps.c @@ -3293,7 +3293,7 @@ static void io_check_error(struct cpu_us outb((inb(0x61) & 0x07) | 0x00, 0x61); /* enable IOCK */ } -static void unknown_nmi_error(unsigned char reason) +static void unknown_nmi_error(struct cpu_user_regs *regs, unsigned char reason) { switch ( opt_nmi[0] ) { @@ -3302,10 +3302,10 @@ static void unknown_nmi_error(unsigned c case 'i': /* 'ignore' */ break; default: /* 'fatal' */ + console_force_unlock(); printk("Uhhuh. NMI received for unknown reason %02x.\n", reason); - printk("Dazed and confused, but trying to continue\n"); printk("Do you have a strange power saving mode enabled?\n"); - kexec_crash(); + fatal_trap(TRAP_nmi, regs); } } @@ -3338,7 +3338,7 @@ void do_nmi(struct cpu_user_regs *regs) else if ( reason & 0x40 ) io_check_error(regs); else if ( !nmi_watchdog ) - unknown_nmi_error((unsigned char)(reason&0xff)); + unknown_nmi_error(regs, (unsigned char)(reason&0xff)); } } --------------060602030301090907040708 Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Disposition: inline _______________________________________________ Xen-devel mailing list Xen-devel@lists.xen.org http://lists.xen.org/xen-devel --------------060602030301090907040708--