From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754739AbcANFSv (ORCPT ); Thu, 14 Jan 2016 00:18:51 -0500 Received: from LGEAMRELO13.lge.com ([156.147.23.53]:56631 "EHLO lgeamrelo13.lge.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753556AbcANFSu (ORCPT ); Thu, 14 Jan 2016 00:18:50 -0500 X-Original-SENDERIP: 156.147.1.125 X-Original-MAILFROM: byungchul.park@lge.com X-Original-SENDERIP: 10.177.222.33 X-Original-MAILFROM: byungchul.park@lge.com Date: Thu, 14 Jan 2016 14:18:40 +0900 From: Byungchul Park To: Frederic Weisbecker Cc: Peter Zijlstra , LKML , Chris Metcalf , Thomas Gleixner , Luiz Capitulino , Christoph Lameter , "Paul E . McKenney" , Mike Galbraith , Rik van Riel Subject: Re: [PATCH 2/4] sched: Consolidate nohz CPU load update code Message-ID: <20160114051840.GA4224@X58A-UD3R> References: <1452700891-21807-1-git-send-email-fweisbec@gmail.com> <1452700891-21807-3-git-send-email-fweisbec@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1452700891-21807-3-git-send-email-fweisbec@gmail.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jan 13, 2016 at 05:01:29PM +0100, Frederic Weisbecker wrote: > #ifdef CONFIG_NO_HZ_COMMON > +static void __update_cpu_load_nohz(struct rq *this_rq, > + unsigned long curr_jiffies, Do we need to pass current jiffies as a function parameter? > + unsigned long load, > + int active) > +{ > + unsigned long pending_updates; > + > + pending_updates = curr_jiffies - this_rq->last_load_update_tick; > + if (pending_updates) { > + this_rq->last_load_update_tick = curr_jiffies; > + /* > + * In the regular NOHZ case, we were idle, this means load 0. > + * In the NOHZ_FULL case, we were non-idle, we should consider > + * its weighted load. > + */ > + __update_cpu_load(this_rq, load, pending_updates, active); > + } > +} > + > /* > * There is no sane way to deal with nohz on smp when using jiffies because the > * cpu doing the jiffies update might drift wrt the cpu doing the jiffy reading > @@ -4467,22 +4486,15 @@ static unsigned long weighted_cpuload(const int cpu) > * Called from nohz_idle_balance() to update the load ratings before doing the > * idle balance. > */ > -static void update_idle_cpu_load(struct rq *this_rq) > +static void update_cpu_load_idle(struct rq *this_rq) > { > - unsigned long curr_jiffies = READ_ONCE(jiffies); > - unsigned long load = weighted_cpuload(cpu_of(this_rq)); > - unsigned long pending_updates; > - > /* > * bail if there's load or we're actually up-to-date. > */ > - if (load || curr_jiffies == this_rq->last_load_update_tick) > + if (weighted_cpuload(cpu_of(this_rq))) > return; > > - pending_updates = curr_jiffies - this_rq->last_load_update_tick; > - this_rq->last_load_update_tick = curr_jiffies; > - > - __update_cpu_load(this_rq, load, pending_updates, 0); > + __update_cpu_load_nohz(this_rq, READ_ONCE(jiffies), 0, 0); This question is not directly related to this patch but I am just curious about... Should we use READ_ONCE on jiffies which is already volatile type?