From mboxrd@z Thu Jan 1 00:00:00 1970 From: Tejun Heo Subject: Re: [PATCH 22/45] percpu_counter: Use get/put_online_cpus_atomic() to prevent CPU offline Date: Mon, 24 Jun 2013 11:06:36 -0700 Message-ID: <20130624180636.GB1918@mtj.dyndns.org> References: <20130623133642.19094.16038.stgit@srivatsabhat.in.ibm.com> <20130623134256.19094.99231.stgit@srivatsabhat.in.ibm.com> <20130624175535.GA1918@mtj.dyndns.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: tglx@linutronix.de, peterz@infradead.org, oleg@redhat.com, paulmck@linux.vnet.ibm.com, rusty@rustcorp.com.au, mingo@kernel.org, akpm@linux-foundation.org, namhyung@kernel.org, walken@google.com, vincent.guittot@linaro.org, laijs@cn.fujitsu.com, rostedt@goodmis.org, wangyun@linux.vnet.ibm.com, xiaoguangrong@linux.vnet.ibm.com, sbw@mit.edu, fweisbec@gmail.com, zhong@linux.vnet.ibm.com, nikunj@linux.vnet.ibm.com, linux-pm@vger.kernel.org, linux-arch@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Al Viro To: "Srivatsa S. Bhat" Return-path: Content-Disposition: inline In-Reply-To: <20130624175535.GA1918@mtj.dyndns.org> Sender: linux-pm-owner@vger.kernel.org List-Id: netdev.vger.kernel.org On Mon, Jun 24, 2013 at 10:55:35AM -0700, Tejun Heo wrote: > > @@ -105,6 +106,7 @@ s64 __percpu_counter_sum(struct percpu_counter *fbc) > > ret += *pcount; > > } > > raw_spin_unlock(&fbc->lock); > > + put_online_cpus_atomic(); > > I don't think this is necessary. CPU on/offlining is explicitly > handled via the hotplug callback which synchronizes through fbc->lock. > __percpu_counter_sum() racing with actual on/offlining doesn't affect > correctness and adding superflous get_online_cpus_atomic() around it > can be misleading. Ah, okay, so you added a debug feature which triggers warning if online mask is accessed without synchronization. Yeah, that makes sense and while the above is not strictly necessary, it probably is better to just add it rather than suppressing the warning in a different way. Can you please at least add a comment explaining that? Thanks. -- tejun