Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755043AbbBTSi7 (ORCPT ); Fri, 20 Feb 2015 13:38:59 -0500 Received: from e37.co.us.ibm.com ([32.97.110.158]:39909 "EHLO e37.co.us.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754858AbbBTSi6 (ORCPT ); Fri, 20 Feb 2015 13:38:58 -0500 Date: Fri, 20 Feb 2015 10:38:49 -0800 From: "Paul E. McKenney" To: Peter Zijlstra Cc: Arjan van de Ven , linux-kernel@vger.kernel.org, mingo@kernel.org, laijs@cn.fujitsu.com, dipankar@in.ibm.com, akpm@linux-foundation.org, mathieu.desnoyers@efficios.com, josh@joshtriplett.org, tglx@linutronix.de, rostedt@goodmis.org, dhowells@redhat.com, edumazet@google.com, dvhart@linux.intel.com, fweisbec@gmail.com, oleg@redhat.com, bobby.prani@gmail.com Subject: Re: [PATCH tip/core/rcu 0/4] Programmatic nestable expedited grace periods Message-ID: <20150220183849.GO5745@linux.vnet.ibm.com> Reply-To: paulmck@linux.vnet.ibm.com References: <20150220050850.GA32639@linux.vnet.ibm.com> <20150220091107.GN21418@twins.programming.kicks-ass.net> <20150220163737.GL5745@linux.vnet.ibm.com> <20150220165409.GU5029@twins.programming.kicks-ass.net> <20150220171442.GM5745@linux.vnet.ibm.com> <54E76FB7.4060005@linux.intel.com> <20150220174359.GW5029@twins.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20150220174359.GW5029@twins.programming.kicks-ass.net> User-Agent: Mutt/1.5.21 (2010-09-15) X-TM-AS-MML: disable X-Content-Scanned: Fidelis XPS MAILER x-cbid: 15022018-0025-0000-0000-000008BAA156 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1945 Lines: 46 On Fri, Feb 20, 2015 at 06:43:59PM +0100, Peter Zijlstra wrote: > On Fri, Feb 20, 2015 at 09:32:39AM -0800, Arjan van de Ven wrote: > > there's a few others as well that I'm chasing down... > > .. but the flip side, prior to running ring 3 code, why NOT do fast expedites? > > So my objections are twofold: > > - I object to fast expedites in principle; they spray IPIs across the > system, so ideally we'd not have them at all, therefore also not at > boot. There are only a few uses of expedited grace periods, despite their having been in the kernel for some years. So people do seem to be exercising appropriate restraint here. > Because as soon as the option exists, people will use it for other > things too. > > - The proposed interface is very much exposed to everybody who wants > it; this again is wide open to (ab)use. > > Once it exists people will start to use, and before you know it we'll > always have that fast counter incremented and we're in IPI hell. Most > likely because someone was lazy and it seemed like a quick fix for > some stupid code. I suppose that another way to keep it private would be to have the declaration in both update.c and rcutorture.c. This would mean that no other file could invoke it, and should keep 0day happy. It would mean that the declarations would be duplicated, but worse things could happen. > And esp. in bootup code you can special case a lot of stuff; there's > limited concurrency esp. because userspace it not there yet. So we might > not actually need those sync calls. I expect that some could be rewritten, but it might not work well for code common to boot and to runtime. Thanx, Paul -- 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/