From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail144.messagelabs.com (mail144.messagelabs.com [216.82.254.51]) by kanga.kvack.org (Postfix) with ESMTP id 6FA5E600044 for ; Tue, 10 Aug 2010 00:33:08 -0400 (EDT) Date: Mon, 9 Aug 2010 21:34:31 -0700 From: Andrew Morton Subject: Re: [PATCH 03/10] Use percpu stats Message-Id: <20100809213431.d7699d46.akpm@linux-foundation.org> In-Reply-To: <1281374816-904-4-git-send-email-ngupta@vflare.org> References: <1281374816-904-1-git-send-email-ngupta@vflare.org> <1281374816-904-4-git-send-email-ngupta@vflare.org> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org To: Nitin Gupta Cc: Pekka Enberg , Minchan Kim , Greg KH , Linux Driver Project , linux-mm , linux-kernel List-ID: On Mon, 9 Aug 2010 22:56:49 +0530 Nitin Gupta wrote: > +/* > + * Individual percpu values can go negative but the sum across all CPUs > + * must always be positive (we store various counts). So, return sum as > + * unsigned value. > + */ > +static u64 zram_get_stat(struct zram *zram, enum zram_stats_index idx) > { > - u64 val; > - > - spin_lock(&zram->stat64_lock); > - val = *v; > - spin_unlock(&zram->stat64_lock); > + int cpu; > + s64 val = 0; > + > + for_each_possible_cpu(cpu) { > + s64 temp; > + unsigned int start; > + struct zram_stats_cpu *stats; > + > + stats = per_cpu_ptr(zram->stats, cpu); > + do { > + start = u64_stats_fetch_begin(&stats->syncp); > + temp = stats->count[idx]; > + } while (u64_stats_fetch_retry(&stats->syncp, start)); > + val += temp; > + } > > + WARN_ON(val < 0); > return val; > } That reimplements include/linux/percpu_counter.h, poorly. Please see the June discussion "[PATCH v2 1/2] tmpfs: Quick token library to allow scalable retrieval of tokens from token jar" for some discussion. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org