Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751842AbdHaQKf (ORCPT ); Thu, 31 Aug 2017 12:10:35 -0400 Received: from mail-io0-f178.google.com ([209.85.223.178]:33084 "EHLO mail-io0-f178.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751583AbdHaQKe (ORCPT ); Thu, 31 Aug 2017 12:10:34 -0400 X-Google-Smtp-Source: ADKCNb7XxrBeUd1CsBQ1YWgXIpcLTu5ze+Z1rWCnNKEyB6DgBzr0NROeEISX9Ll0C5syYYORfEYwgmVZPLrkHtoU6GU= MIME-Version: 1.0 In-Reply-To: <20170831115802.26365-6-brendan.jackman@arm.com> References: <20170831115802.26365-1-brendan.jackman@arm.com> <20170831115802.26365-6-brendan.jackman@arm.com> From: Vincent Guittot Date: Thu, 31 Aug 2017 18:10:12 +0200 Message-ID: Subject: Re: [PATCH v3 5/5] sched/fair: Fix use of find_idlest_group when local group is idlest To: Brendan Jackman Cc: Ingo Molnar , Peter Zijlstra , linux-kernel , Dietmar Eggemann , Josef Bacik , 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 Content-Length: 1591 Lines: 40 On 31 August 2017 at 13:58, Brendan Jackman wrote: > find_idlest_group returns NULL when the local group is idlest. The > caller then continues the find_idlest_group search at a lower level > of the current CPU's sched_domain hierarchy. find_idlest_group_cpu is > not consulted and, crucially, @new_cpu is not updated. This means the > search is pointless and we return @prev_cpu from select_task_rq_fair. > > This is fixed by initialising @new_cpu to @cpu instead of > @prev_cpu. > > Signed-off-by: Brendan Jackman > Cc: Dietmar Eggemann > Cc: Vincent Guittot > Cc: Josef Bacik > Cc: Ingo Molnar > Cc: Morten Rasmussen > Cc: Peter Zijlstra Reviewed-by: Vincent Guittot > --- > kernel/sched/fair.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c > index 2608091..f93cb97 100644 > --- a/kernel/sched/fair.c > +++ b/kernel/sched/fair.c > @@ -5567,7 +5567,7 @@ find_idlest_group_cpu(struct sched_group *group, struct task_struct *p, int this > static inline int find_idlest_cpu(struct sched_domain *sd, struct task_struct *p, > int cpu, int prev_cpu, int sd_flag) > { > - int new_cpu = prev_cpu; > + int new_cpu = cpu; > > if (!cpumask_intersects(sched_domain_span(sd), &p->cpus_allowed)) > return prev_cpu; > -- > 2.7.4 >