Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932796AbdHYNjs (ORCPT ); Fri, 25 Aug 2017 09:39:48 -0400 Received: from mail-it0-f51.google.com ([209.85.214.51]:34788 "EHLO mail-it0-f51.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932218AbdHYNjr (ORCPT ); Fri, 25 Aug 2017 09:39:47 -0400 MIME-Version: 1.0 In-Reply-To: <20170825101632.28065-5-brendan.jackman@arm.com> References: <20170825101632.28065-1-brendan.jackman@arm.com> <20170825101632.28065-5-brendan.jackman@arm.com> From: Vincent Guittot Date: Fri, 25 Aug 2017 15:39:25 +0200 Message-ID: Subject: Re: [PATCH v2 4/5] sched/fair: Fix use of find_idlest_group when no groups are allowed To: Brendan Jackman Cc: Ingo Molnar , Peter Zijlstra , linux-kernel , Joel Fernandes , Andres Oportus , 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: 1920 Lines: 52 On 25 August 2017 at 12:16, Brendan Jackman wrote: > When p is allowed on none of the CPUs in the sched_domain, we > currently return NULL from find_idlest_group, and pointlessly > continue the search on lower sched_domain levels (where p is also not > allowed) before returning prev_cpu regardless (as we have not updated > new_cpu). > > Add an explicit check for this case, and a comment to > find_idlest_group. Now when find_idlest_group returns NULL, it always > means that the local group is allowed and idlest. > > 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 | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c > index 0ce75bbcde45..26080917ff8d 100644 > --- a/kernel/sched/fair.c > +++ b/kernel/sched/fair.c > @@ -5380,6 +5380,8 @@ static unsigned long capacity_spare_wake(int cpu, struct task_struct *p) > /* > * find_idlest_group finds and returns the least busy CPU group within the > * domain. > + * > + * Assumes p is allowed on at least one CPU in sd. > */ > static struct sched_group * > find_idlest_group(struct sched_domain *sd, struct task_struct *p, > @@ -5567,6 +5569,9 @@ static inline int find_idlest_cpu(struct sched_domain *sd, struct task_struct *p > { > int new_cpu = prev_cpu; > > + if (!cpumask_intersects(sched_domain_span(sd), &p->cpus_allowed)) > + return prev_cpu; > + > while (sd) { > struct sched_group *group; > struct sched_domain *tmp; > -- > 2.14.1 >