Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp633543imm; Wed, 4 Jul 2018 03:21:41 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdpAgwi3BVexDWetJtRiocPYgxhs9aQEAVNRVW1YmyR/DLkKwaXjhW7Ge6AW4rfDjZoi84A X-Received: by 2002:a65:611a:: with SMTP id z26-v6mr1340043pgu.61.1530699701591; Wed, 04 Jul 2018 03:21:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530699701; cv=none; d=google.com; s=arc-20160816; b=Jbj5wM3oewcYYckptlW7IB3kt6HoXgfpCJYBChzQgUQEexcubfc79mGKp1q1Z2lQ6c E5RVhN3REtm86FrfQJZk4gueRgLv7Nbkr3VUarqX+fTEQ+j1rl20oE2PqMbx39rX0Pio l8kFS82rIwDky5CZ4KVOfYhJkQkF5HNGVpLaIHh0H3aUoQd72IeHkWoUQiauPYMiwgsW pzLJP+WNeLPJhJueZyC+jboMsJ3JXNslHFdp9QMsDyQmCHKhQxLUB9kQLyGSTsTeH326 sm5g4Fzx3Fz1tFyqhny1vQ+h9JIC+v4ZyNlcIXhNK+KdrhuB0PJK/JjiS/p2oxv9RMAR YOwQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=8O3Fak+fg+DOqjgP/qE9knThx9q3vI3iQRohSD48dkY=; b=FDATTONQeoj08XndD18boSUPGIsW9R8O9lZlr4x4LdOTHGdVIlhbrnD/+doUgLIwMh Fj96NDu8J7uVqL3qtrdJqVah7avksPywEN/l6ZCtN1qFlw8h6lwlgzpZim6ab3c2Ez3x EiNAFLiahx5JJyXvLY5WnaSajdkYTYUUDojP242EiuTGJrhPp/yya7VOzdJ3Z+Klc9rU NC9zIefv2JIPo8DOOhiaH8jGyTPp0mRgGSUbyNrVaDuxE7qVUbII2EPbmBAShOCJ+rGo w2LfY/aEkwXp5HM20HaMipJap4UMh9autDsBTWu5N6lUugd5LCIgjj7//MJSDd/2966k xWmg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t128-v6si2875597pgt.598.2018.07.04.03.21.27; Wed, 04 Jul 2018 03:21:41 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934587AbeGDKSa (ORCPT + 99 others); Wed, 4 Jul 2018 06:18:30 -0400 Received: from foss.arm.com ([217.140.101.70]:35080 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934329AbeGDKS1 (ORCPT ); Wed, 4 Jul 2018 06:18:27 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id B3D0118A; Wed, 4 Jul 2018 03:18:26 -0700 (PDT) Received: from e105550-lin.cambridge.arm.com (e105550-lin.cambridge.arm.com [10.1.211.30]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 3C6D63F5AD; Wed, 4 Jul 2018 03:18:25 -0700 (PDT) From: Morten Rasmussen To: peterz@infradead.org, mingo@redhat.com Cc: valentin.schneider@arm.com, dietmar.eggemann@arm.com, vincent.guittot@linaro.org, gaku.inami.xh@renesas.com, linux-kernel@vger.kernel.org, Morten Rasmussen Subject: [PATCHv4 09/12] sched/fair: Set rq->rd->overload when misfit Date: Wed, 4 Jul 2018 11:17:47 +0100 Message-Id: <1530699470-29808-10-git-send-email-morten.rasmussen@arm.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1530699470-29808-1-git-send-email-morten.rasmussen@arm.com> References: <1530699470-29808-1-git-send-email-morten.rasmussen@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Valentin Schneider Idle balance is a great opportunity to pull a misfit task. However, there are scenarios where misfit tasks are present but idle balance is prevented by the overload flag. A good example of this is a workload of n identical tasks. Let's suppose we have a 2+2 Arm big.LITTLE system. We then spawn 4 fairly CPU-intensive tasks - for the sake of simplicity let's say they are just CPU hogs, even when running on big CPUs. They are identical tasks, so on an SMP system they should all end at (roughly) the same time. However, in our case the LITTLE CPUs are less performing than the big CPUs, so tasks running on the LITTLEs will have a longer completion time. This means that the big CPUs will complete their work earlier, at which point they should pull the tasks from the LITTLEs. What we want to happen is summarized as follows: a,b,c,d are our CPU-hogging tasks _ signifies idling LITTLE_0 | a a a a _ _ LITTLE_1 | b b b b _ _ ---------|------------- big_0 | c c c c a a big_1 | d d d d b b ^ ^ Tasks end on the big CPUs, idle balance happens and the misfit tasks are pulled straight away This however won't happen, because currently the overload flag is only set when there is any CPU that has more than one runnable task - which may very well not be the case here if our CPU-hogging workload is all there is to run. As such, this commit sets the overload flag in update_sg_lb_stats when a group is flagged as having a misfit task. cc: Ingo Molnar cc: Peter Zijlstra Signed-off-by: Valentin Schneider Signed-off-by: Morten Rasmussen --- kernel/sched/fair.c | 6 ++++-- kernel/sched/sched.h | 6 +++++- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index d0641ba7bea1..de84f5a9a65a 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -8163,7 +8163,7 @@ static bool update_nohz_stats(struct rq *rq, bool force) * @load_idx: Load index of sched_domain of this_cpu for load calc. * @local_group: Does group contain this_cpu. * @sgs: variable to hold the statistics for this group. - * @overload: Indicate more than one runnable task for any CPU. + * @overload: Indicate pullable load (e.g. >1 runnable task). */ static inline void update_sg_lb_stats(struct lb_env *env, struct sched_group *group, int load_idx, @@ -8207,8 +8207,10 @@ static inline void update_sg_lb_stats(struct lb_env *env, sgs->idle_cpus++; if (env->sd->flags & SD_ASYM_CPUCAPACITY && - sgs->group_misfit_task_load < rq->misfit_task_load) + sgs->group_misfit_task_load < rq->misfit_task_load) { sgs->group_misfit_task_load = rq->misfit_task_load; + *overload = 1; + } } /* Adjust by relative CPU capacity of the group */ diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h index e1dc85d1bfdd..377545b5aa15 100644 --- a/kernel/sched/sched.h +++ b/kernel/sched/sched.h @@ -695,7 +695,11 @@ struct root_domain { cpumask_var_t span; cpumask_var_t online; - /* Indicate more than one runnable task for any CPU */ + /* + * Indicate pullable load on at least one CPU, e.g: + * - More than one runnable task + * - Running task is misfit + */ int overload; /* -- 2.7.4