Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754612AbZCRD4T (ORCPT ); Tue, 17 Mar 2009 23:56:19 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752727AbZCRD4G (ORCPT ); Tue, 17 Mar 2009 23:56:06 -0400 Received: from fgwmail5.fujitsu.co.jp ([192.51.44.35]:37470 "EHLO fgwmail5.fujitsu.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751557AbZCRD4F (ORCPT ); Tue, 17 Mar 2009 23:56:05 -0400 Date: Wed, 18 Mar 2009 12:54:34 +0900 From: KAMEZAWA Hiroyuki To: bharata@linux.vnet.ibm.com Cc: Peter Zijlstra , balbir@linux.vnet.ibm.com, Li Zefan , linux-kernel@vger.kernel.org, Dhaval Giani , Paul Menage , Ingo Molnar Subject: Re: [PATCH -tip] cpuacct: Make cpuacct hierarchy walk in cpuacct_charge() safe when rcupreempt is used. Message-Id: <20090318125434.63d833e4.kamezawa.hiroyu@jp.fujitsu.com> In-Reply-To: <20090318032558.GB3960@in.ibm.com> References: <20090317061754.GD3314@in.ibm.com> <49BF42FB.4030103@cn.fujitsu.com> <20090317073649.GH3314@in.ibm.com> <20090317131251.GU16897@balbir.in.ibm.com> <1237296361.7867.16.camel@twins> <20090317135938.GV16897@balbir.in.ibm.com> <1237298686.7867.17.camel@twins> <20090318032558.GB3960@in.ibm.com> Organization: FUJITSU Co. LTD. X-Mailer: Sylpheed 2.5.0 (GTK+ 2.10.14; i686-pc-mingw32) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2376 Lines: 70 On Wed, 18 Mar 2009 08:55:58 +0530 Bharata B Rao wrote: > On Tue, Mar 17, 2009 at 03:04:46PM +0100, Peter Zijlstra wrote: > > On Tue, 2009-03-17 at 19:29 +0530, Balbir Singh wrote: > > > * Peter Zijlstra [2009-03-17 14:26:01]: > > > > > > > On Tue, 2009-03-17 at 18:42 +0530, Balbir Singh wrote: > > > > > > > > > I'd like to get the patches in -tip and see the results, I would > > > > > recommend using percpu_counter_sum() while reading the data as an > > > > > enhancement to this patch. If user space does not overwhelm with a lot > > > > > of reads, sum would work out better. > > > > > > > > You trust userspace? I'd rather not. > > > > > > > > > > Fair enough.. A badly written application monitor can frequently read > > > this data and cause horrible performance issues. On the other hand > > > large number of CPUs can make the lag even worse. Is it time yet for > > > percpu_counter batch numbers? I've tested this patch and the results > > > were not badly off the mark. > > > > I'd rather err on the side of caution here, you might get some crazy > > folks depending on it and then expecting us to maintain it. > > So if we want to be cautious, we could use percpu_counter_sum() as > Balbir suggested. That would address both the issues with percpu_counter > that I pointed out earlier: > > - Readers are serialized with writers and we get consistent/correct > values during reads. > - Negates the effect of batching and reads would always get updated/current > values. > Is this wrong ? == -- CONFIG_32BIT s64 static inline s64 percpu_counter_read_slow(struct percpu_counter *fbc) { s64 val; retry: val = fbc->counter; smp_mb(); wait_spin_unlock(&fbc->lock); if (fbc->counter < val) { goto retry; return val; } == Thanks, -Kame > Regards, > Bharata. > -- > 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/ > -- 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/