Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752968Ab2KCIVB (ORCPT ); Sat, 3 Nov 2012 04:21:01 -0400 Received: from a.mx.secunet.com ([195.81.216.161]:59652 "EHLO a.mx.secunet.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751134Ab2KCIU5 (ORCPT ); Sat, 3 Nov 2012 04:20:57 -0400 Date: Sat, 3 Nov 2012 09:20:47 +0100 From: Steffen Klassert To: Christoph Lameter Cc: Shan Wei , David Miller , timo.teras@iki.fi, NetDev , Kernel-Maillist Subject: Re: [PATCH v2 1/9] net: core: use this_cpu_ptr per-cpu helper Message-ID: <20121103082047.GA20868@secunet.com> References: <5093EE47.20700@gmail.com> <0000013ac239c004-87f4c3e0-5c6a-4979-817f-0a0c4445a4e9-000000@email.amazonses.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <0000013ac239c004-87f4c3e0-5c6a-4979-817f-0a0c4445a4e9-000000@email.amazonses.com> User-Agent: Mutt/1.5.21 (2010-09-15) X-OriginalArrivalTime: 03 Nov 2012 08:20:47.0699 (UTC) FILETIME=[209FC230:01CDB99C] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1166 Lines: 28 On Fri, Nov 02, 2012 at 05:44:55PM +0000, Christoph Lameter wrote: > On Sat, 3 Nov 2012, Shan Wei wrote: > > +++ b/net/core/flow.c > > @@ -327,11 +327,9 @@ static void flow_cache_flush_tasklet(unsigned long data) > > static void flow_cache_flush_per_cpu(void *data) > > { > > struct flow_flush_info *info = data; > > - int cpu; > > struct tasklet_struct *tasklet; > > > > - cpu = smp_processor_id(); > > - tasklet = &per_cpu_ptr(info->cache->percpu, cpu)->flush_tasklet; > > + tasklet = &this_cpu_ptr(info->cache->percpu)->flush_tasklet > > Another case for the use of this_cpu_read Actually, smp_processor_id() is used if either preemtion is off or in a thread that is bound to the current cpu. So all code that uses smp_processor_id() should be able to use __this_cpu_read instead of this_cpu_read. In this case, flow_cache_flush_per_cpu() is called via smp_call_function(), so it is bound on the current cpu. -- 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/