From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755316AbdLTO12 (ORCPT ); Wed, 20 Dec 2017 09:27:28 -0500 Received: from mail-io0-f193.google.com ([209.85.223.193]:35506 "EHLO mail-io0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753868AbdLTO11 (ORCPT ); Wed, 20 Dec 2017 09:27:27 -0500 X-Google-Smtp-Source: ACJfBoubquOYe3cCwbNjBY959prDiBaLWPGPp5kGIDIBXoETNLVxZCl11jVBpLTtrYoRnzS18xWinzN2yfwJr7fPlL0= MIME-Version: 1.0 In-Reply-To: <20171220140906.oied65gn6afvvafc@hirez.programming.kicks-ass.net> References: <20171201180157.18937-1-brendan.jackman@arm.com> <20171201180157.18937-2-brendan.jackman@arm.com> <20171220140906.oied65gn6afvvafc@hirez.programming.kicks-ass.net> From: Vincent Guittot Date: Wed, 20 Dec 2017 15:27:05 +0100 Message-ID: Subject: Re: [PATCH v2 1/2] sched: force update of blocked load of idle cpus To: Peter Zijlstra Cc: Brendan Jackman , Dietmar Eggemann , Ingo Molnar , linux-kernel , Ingo Molnar , Morten Rasmussen Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20 December 2017 at 15:09, Peter Zijlstra wrote: > On Fri, Dec 01, 2017 at 06:01:56PM +0000, Brendan Jackman wrote: > >> @@ -9210,7 +9256,15 @@ static void nohz_idle_balance(struct rq *this_rq, enum cpu_idle_type idle) >> cpu_load_update_idle(rq); >> rq_unlock_irq(rq, &rf); >> >> - rebalance_domains(rq, CPU_IDLE); >> + update_blocked_averages(balance_cpu); >> + /* >> + * This idle load balance softirq may have been >> + * triggered only to update the blocked load and shares >> + * of idle CPUs (which we have just done for >> + * balance_cpu). In that case skip the actual balance. >> + */ >> + if (!in_nohz_stats_kick(this_cpu)) >> + rebalance_domains(rq, idle); >> } >> >> if (time_after(next_balance, rq->next_balance)) { > >> @@ -9336,7 +9396,12 @@ static __latent_entropy void run_rebalance_domains(struct softirq_action *h) >> * and abort nohz_idle_balance altogether if we pull some load. >> */ >> nohz_idle_balance(this_rq, idle); >> - rebalance_domains(this_rq, idle); >> + update_blocked_averages(this_rq->cpu); >> + if (!in_nohz_stats_kick(this_rq->cpu)) >> + rebalance_domains(this_rq, idle); >> +#ifdef CONFIG_NO_HZ_COMMON >> + clear_bit(NOHZ_STATS_KICK, nohz_flags(this_rq->cpu)); >> +#endif >> } >> >> /* > > You're doing the same thing to both (all) callsites of > rebalance_domains(), does that not suggest doing it inside and leaving > update_blocked_averages() where it is? The goal of moving update_blocked_averages() outside rebalance_domains is to not add a new parameter or use a special cpu_idle_type value in rebalance_domains parameters in order to abort the rebalance sequence just after updating blocked load > >