Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754577AbYK0MRd (ORCPT ); Thu, 27 Nov 2008 07:17:33 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752599AbYK0MRY (ORCPT ); Thu, 27 Nov 2008 07:17:24 -0500 Received: from casper.infradead.org ([85.118.1.10]:36064 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751545AbYK0MRX (ORCPT ); Thu, 27 Nov 2008 07:17:23 -0500 Subject: Re: [patch 05/24] perfmon: X86 generic code (x86) From: Peter Zijlstra To: eranian@gmail.com Cc: Andi Kleen , Thomas Gleixner , linux-kernel@vger.kernel.org, akpm@linux-foundation.org, mingo@elte.hu, x86@kernel.org, Stephen Rothwell , aris@redhat.com, Cyrill Gorcunov , marco@linux-mips.com In-Reply-To: <7c86c4470811270404q2ce1b503lf78c24d5c2223c44@mail.gmail.com> References: <492d0be1.09cc660a.0b75.44b7@mx.google.com> <20081126140054.GX6703@one.firstfloor.org> <20081127100602.GF6703@one.firstfloor.org> <7c86c4470811270209q18d4e83aq8901837159838cc4@mail.gmail.com> <20081127113115.GH6703@one.firstfloor.org> <7c86c4470811270335p2dbd61ebpe2c584e32d8b2292@mail.gmail.com> <1227786746.4454.1468.camel@twins> <7c86c4470811270404q2ce1b503lf78c24d5c2223c44@mail.gmail.com> Content-Type: text/plain Content-Transfer-Encoding: 7bit Date: Thu, 27 Nov 2008 13:16:38 +0100 Message-Id: <1227788198.4454.1498.camel@twins> Mime-Version: 1.0 X-Mailer: Evolution 2.24.1 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2111 Lines: 48 On Thu, 2008-11-27 at 13:04 +0100, stephane eranian wrote: > Peter, > > On Thu, Nov 27, 2008 at 12:52 PM, Peter Zijlstra wrote: > > On Thu, 2008-11-27 at 12:35 +0100, stephane eranian wrote: > >> On Thu, Nov 27, 2008 at 12:31 PM, Andi Kleen wrote: > >> >> The only reason why I have to deal with NMI is not so much to allow > >> >> for profiling irq-off regions but because I have to share the PMU with > >> >> the NMI watchdog. Otherwise I'd have to fail or disable the NMI watchdog > >> >> on the fly. > >> > > >> > The NMI watchdog is now off by default so failing with it enabled > >> > is fine. > >> > >> Yes, but most likely it is on in distro kernels. > > > > So? You can disable it on the fly when there is a perfmon user. > > > Yes, you can. There is clearly an interface to do this. I think this is the > best solution. I know it can work because it experimented with this approach > no later than last month. But I ran into a bug which I reported on LKML. I did > not provide a patch because I did not fully understand the connection to > suspend/resume. > > The bug has to do with some obscure suspend/resume sequence in: > > void setup_apic_nmi_watchdog(void *unused) > { > if (__get_cpu_var(wd_enabled)) > return; > > /* cheap hack to support suspend/resume */ > /* if cpu0 is not active neither should the other cpus */ > if (smp_processor_id() != 0 && atomic_read(&nmi_active) <= 0) > return; > > Basically, when you re-enable the NMI watchdog, it is not always re-enabled > correctly on all CPUs, it depends on the order if which they process the IPI. Hmm, either we loose that bit and fix the suspend/resume bit properly, or we can send the IPIs one by one in the correct order ;-) Dunno, CC'ed all the folks who touched it last. -- 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/