Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp4274046pxb; Mon, 8 Feb 2021 12:08:21 -0800 (PST) X-Google-Smtp-Source: ABdhPJwN1DhZSEnnkFutaL0XaUhsQr4PGh5kI8R+zQpQAXKJZyxXS0N7m4ndYq7dHosHvRjq66Na X-Received: by 2002:a17:906:af86:: with SMTP id mj6mr18665157ejb.509.1612814901599; Mon, 08 Feb 2021 12:08:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612814901; cv=none; d=google.com; s=arc-20160816; b=q18wcd35Lz9BqNZP8J1Qtt52FO2W5Fcqsk3PDTHenuMLeu7oZ2/KCvfl12M7neNRAj MgkKqUd6aKsbWk0QrYArOAMUE0W384MnEtrWJhzDXwULpgGgClNpkJt3rSOs/fvTCZcR 95ARZZhYefOc3pXdNhh3SfvL8X8mbaAHa/FUETKclHkbqYMVioHOb60599GqoSRinf4f p0HPPFBxsicYj3uAqWgnnXtu93u9WlB2Qg9bSRl3HP7gMwkxTHjwMJJ/O5lCOJa1UlS3 UB0wOnQ4xNF0LDoUoU1MTfDBf1u0p7PW+YVfGA7pTOvex7y3uNeGgj7c+0VbPoGoS1D8 luEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:user-agent :references:in-reply-to:subject:cc:to:from; bh=/0Srva0ap9CAF4nvauxHfjtyrXEwJghWFfLCRAR7xV0=; b=pPBP5x9V1+/LT8aq7LQZpFtJcredaOoDjBR/nv6pPYgtwsiBXbu9uy8ZFZ7Av/uovT 576YQGUbpCMec0j5eqWCBG/vxw9FefVeEtfTGE88J/CBxNqcgNU6n6y/juCtGJlvKIeB AemuPZGsWMC6J6EQ8ZavmcVDa5VKsMDtkTZ7wc5kGXOd5HTIK8ecWJ4bKha4uih2KGSE R2Plp8HARIgRDfMW9TDCQbKr3CNLj9XraE+NmS2Vq6MBSI0FjFD5idSDt+q2DD8g4ONe T6aiPicD3NC2iXnTQ2bs6vS8bvX8gLb32GDrRo1mvFMey7Rdy6FjW41yJL9zFCEq6N+Z PgRw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a4si6779069eds.33.2021.02.08.12.07.58; Mon, 08 Feb 2021 12:08:21 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235995AbhBHUHQ (ORCPT + 99 others); Mon, 8 Feb 2021 15:07:16 -0500 Received: from foss.arm.com ([217.140.110.172]:39918 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235475AbhBHSZn (ORCPT ); Mon, 8 Feb 2021 13:25:43 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 08BE01042; Mon, 8 Feb 2021 10:24:55 -0800 (PST) Received: from e113632-lin (e113632-lin.cambridge.arm.com [10.1.194.46]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id AB3C33F73D; Mon, 8 Feb 2021 10:24:53 -0800 (PST) From: Valentin Schneider To: Vincent Guittot Cc: linux-kernel , Peter Zijlstra , Ingo Molnar , Dietmar Eggemann , Morten Rasmussen , Qais Yousef , Quentin Perret , Pavan Kondeti , Rik van Riel Subject: Re: [PATCH 8/8] sched/fair: Relax task_hot() for misfit tasks In-Reply-To: References: <20210128183141.28097-1-valentin.schneider@arm.com> <20210128183141.28097-9-valentin.schneider@arm.com> User-Agent: Notmuch/0.21 (http://notmuchmail.org) Emacs/26.3 (x86_64-pc-linux-gnu) Date: Mon, 08 Feb 2021 18:24:47 +0000 Message-ID: MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/02/21 17:21, Vincent Guittot wrote: > On Thu, 28 Jan 2021 at 19:32, Valentin Schneider > wrote: >> >> Misfit tasks can and will be preempted by the stopper to migrate them over >> to a higher-capacity CPU. However, when runnable but not current misfit >> tasks are scanned by the load balancer (i.e. detach_tasks()), the >> task_hot() ratelimiting logic may prevent us from enqueuing said task onto >> a higher-capacity CPU. >> >> Align detach_tasks() with the active-balance logic and let it pick a >> cache-hot misfit task when the destination CPU can provide a capacity >> uplift. >> >> Signed-off-by: Valentin Schneider >> --- >> kernel/sched/fair.c | 11 +++++++++++ >> 1 file changed, 11 insertions(+) >> >> diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c >> index cba9f97d9beb..c2351b87824f 100644 >> --- a/kernel/sched/fair.c >> +++ b/kernel/sched/fair.c >> @@ -7484,6 +7484,17 @@ static int task_hot(struct task_struct *p, struct lb_env *env) >> if (env->sd->flags & SD_SHARE_CPUCAPACITY) >> return 0; >> >> + /* >> + * On a (sane) asymmetric CPU capacity system, the increase in compute >> + * capacity should offset any potential performance hit caused by a >> + * migration. >> + */ >> + if (sd_has_asym_cpucapacity(env->sd) && >> + env->idle != CPU_NOT_IDLE && >> + !task_fits_capacity(p, capacity_of(env->src_cpu)) && >> + cpu_capacity_greater(env->dst_cpu, env->src_cpu)) > > Why not using env->migration_type to directly detect that it's a > misfit task active migration ? > This is admittedly a kludge. Consider the scenario described in patch 7/8, i.e.: - there's a misfit task running on a LITTLE CPU - a big CPU completes its work and is about to go through newidle_balance() Now, consider by the time that big CPU gets into load_balance(), the misfit task on the LITTLE CPU got preempted by a percpu kworker. As of right now, it's quite likely the imbalance won't be classified as group_misfit_task, but as group_overloaded (depends on the topology / workload, but that's a symptom I've been seeing). Unfortunately, even if we e.g. change the misfit load-balance logic to also track preempted misfit tasks (rather than just the rq's current), this could still happen AFAICT. Long story short, we already trigger an active-balance to upmigrate running misfit tasks, this changes task_hot() to allow any preempted task that doesn't fit on its CPU to be upmigrated (regardless of the imbalance classification). >> + return 0; >> + >> /* >> * Buddy candidates are cache hot: >> */ >> -- >> 2.27.0 >>