Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932360AbbHGOin (ORCPT ); Fri, 7 Aug 2015 10:38:43 -0400 Received: from mail-wi0-f173.google.com ([209.85.212.173]:33887 "EHLO mail-wi0-f173.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932072AbbHGOil (ORCPT ); Fri, 7 Aug 2015 10:38:41 -0400 Date: Fri, 7 Aug 2015 16:38:37 +0200 From: Michal Hocko To: Hidehiro Kawai Cc: Jonathan Corbet , Peter Zijlstra , Ingo Molnar , "Eric W. Biederman" , "H. Peter Anvin" , Andrew Morton , Thomas Gleixner , Vivek Goyal , linux-doc@vger.kernel.org, x86@kernel.org, kexec@lists.infradead.org, linux-kernel@vger.kernel.org, Masami Hiramatsu Subject: Re: [V3 PATCH 0/4] Fix race issues among panic, NMI and crash_kexec Message-ID: <20150807143836.GI30785@dhcp22.suse.cz> References: <20150806054543.25766.29590.stgit@softrs> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20150806054543.25766.29590.stgit@softrs> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2501 Lines: 68 JFYI I have those patches tested on the largish box. Will come back to you as soon as I have some feedback. I will also try to review these patches sometimes next week. Thanks! On Thu 06-08-15 14:45:43, Hidehiro Kawai wrote: > When an HA cluster software or administrator detects non-response > of a host, they issue an NMI to the host to completely stop current > works and take a crash dump. If the kernel has already panicked > or is capturing a crash dump at that time, further NMI can cause > a crash dump failure. > > Also, crash_kexec() called from oops context and panic() can > cause race conditions. > > To solve these issue, this patch set does following things: > > - Don't panic on NMI if the kernel has already panicked > - Extend exclusion control currently done by panic_lock to crash_kexec > - Introduce "noextnmi" boot option which masks external NMI at the > boot time (supported only for x86) > > V3: > - Introduce nmi_panic() macro to reduce code duplication > - In the case of panic on NMI, don't return from NMI handlers > if another cpu already panicked > > V2: > - Use atomic_cmpxchg() instead of current spin_trylock() to exclude > concurrent accesses to panic() and crash_kexec() > - Don't introduce no-lock version of panic() and crash_kexec() > > --- > > Hidehiro Kawai (4): > panic/x86: Fix re-entrance problem due to panic on NMI > panic/x86: Allow cpus to save registers even if they are looping in NMI context > kexec: Fix race between panic() and crash_kexec() called directly > x86/apic: Introduce noextnmi boot option > > > Documentation/kernel-parameters.txt | 4 ++++ > arch/x86/kernel/apic/apic.c | 17 ++++++++++++++++- > arch/x86/kernel/nmi.c | 15 +++++++++++---- > arch/x86/kernel/reboot.c | 11 +++++++++++ > include/linux/kernel.h | 21 +++++++++++++++++++++ > kernel/kexec.c | 20 ++++++++++++++++++++ > kernel/panic.c | 23 ++++++++++++++++++++--- > kernel/watchdog.c | 5 +++-- > 8 files changed, 106 insertions(+), 10 deletions(-) > > > -- > Hidehiro Kawai > Hitachi, Ltd. Research & Development Group > > -- Michal Hocko SUSE Labs -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/