Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755982AbaBKU5m (ORCPT ); Tue, 11 Feb 2014 15:57:42 -0500 Received: from g4t0017.houston.hp.com ([15.201.24.20]:5957 "EHLO g4t0017.houston.hp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753910AbaBKU5k (ORCPT ); Tue, 11 Feb 2014 15:57:40 -0500 Message-ID: <1392151870.5612.159.camel@misato.fc.hp.com> Subject: Re: [PATCH 01/51] CPU hotplug: Provide lockless versions of callback registration functions From: Toshi Kani To: "Srivatsa S. Bhat" Cc: ego@linux.vnet.ibm.com, "paulus@samba.org" , "oleg@redhat.com" , "rusty@rustcorp.com.au" , "peterz@infradead.org" , "tglx@linutronix.de" , "akpm@linux-foundation.org" , "mingo@kernel.org" , "paulmck@linux.vnet.ibm.com" , "tj@kernel.org" , "walken@google.com" , "linux@arm.linux.org.uk" , "linux-kernel@vger.kernel.org" , "Rafael J. Wysocki" Date: Tue, 11 Feb 2014 13:51:10 -0700 In-Reply-To: <52FA77EA.7050105@linux.vnet.ibm.com> References: <20140205220251.19080.92336.stgit@srivatsabhat.in.ibm.com> <20140205220447.19080.9460.stgit@srivatsabhat.in.ibm.com> <1392081980.5612.123.camel@misato.fc.hp.com> <52F9ED11.5010800@linux.vnet.ibm.com> <1392136436.5612.131.camel@misato.fc.hp.com> <20140211171805.GA3932@in.ibm.com> <1392140115.5612.135.camel@misato.fc.hp.com> <52FA77EA.7050105@linux.vnet.ibm.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.8.5 (3.8.5-2.fc19) Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2014-02-12 at 00:50 +0530, Srivatsa S. Bhat wrote: > On 02/11/2014 11:05 PM, Toshi Kani wrote: : > > How about this? foo_cpu_notifier returns NOP when foo_notifier_ready is > > false. > > > > register_cpu_notifier(&foobar_cpu_notifier); > > > > get_online_cpus(); > > > > for_each_online_cpu(cpu) > > init_cpu(cpu); > > > > foo_notifier_ready = true; > > > > put_online_cpus(); > > > > Nah, that looks a lot like some quick-n-dirty hack ;-( > It would also amount to burdening the various subsystems to add weird-looking > pieces of code such as this in their callbacks: > > if (!foo_notifier_ready) > return NOTIFY_OK; > > This only makes it all the more evident that the callback registration APIs > exposed by the CPU hotplug core is poorly designed. > > What we need instead, is an elegant, well-defined and easy-to-use set of > interfaces/APIs exposed by the core CPU hotplug code to the various > subsystems. I don't think we should worry so much about the fact that > we can't use the familiar get/put_online_cpus() in this type of callback > registration scenario. We can introduce a sane set of APIs that work > well in such situations and use them consistently. > For example, something like the code snippet shown below looks pretty > neat to me: > > cpu_notifier_register_begin(); > > for_each_online_cpu(cpu) > init_cpu(cpu); > > register_cpu_notifier(&foobar_cpu_notifier); > > cpu_notifier_register_done(); > > What do you think? I agree that it is cleaner for the callers as long as people understand how to use them. Can you document them properly so that they know when they need to use them instead of the familiar get/put_online_cpus()? Thanks, -Toshi -- 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/