Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2717078pxb; Tue, 19 Jan 2021 04:30:48 -0800 (PST) X-Google-Smtp-Source: ABdhPJzrJ6TbYtzThbtE77GmtGRXYEKzQl+Z7+qoQXccnW6iVM0iddphucDY8wFX8KolOwwxlC08 X-Received: by 2002:aa7:d504:: with SMTP id y4mr3098123edq.372.1611059448562; Tue, 19 Jan 2021 04:30:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611059448; cv=none; d=google.com; s=arc-20160816; b=kSSCqo7xmFwYyqCfPQi5aD08LZH5DGrKbBZ6/YJmFjrXNyX74YhMF1dgAp3+ZCPXoL pH+Zb32M8TfWaGQTUHEq0ecbi0ySxsciaecZRAlCY8W8oloDDqDz86YoIxDRdjXyhqyD xFaxXULC8Sovc6zfiG4ElartMG8ICZ3JeLfK5xR3S4ojIqwcHC9kCDMoC5V6MB+KTza5 OnmjnUypR0Air4wpsJnnIM6R4jbSEhFg7JJMK7jp5jKDkI88Fdj9q9YDf7hW1n/3YVyL uUrlNu0TK2TlWet2pqdAhvb3SnqMgp/HqJe4fwx/CF2JfITjJrNqrpcqSG+S08mDe4WP Mjsw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=jHKN0NTqQNjjyCh+428DwJXo31c9x/gfRKwVITohfOc=; b=fW/DJRhKQsGSvlFE6uiw8QC9EK46EvCf40ED2B95ZVngLpWDAtIq/+zRk2KF1YIXsv dCk6NR6VdbFfoRshGLl1GhximeEhBosXKWYHjM4zK+3a8N2015scJuG1o0GJeX/m+BMn I/JOExESOfVRTtH0gvM1gwGEGi2JUUTUZ85x3Q1GLBQJhizMpODmKN5memJL70HY43n+ 1fCMrVrnXc2sSooJz0SYR5aJzlrPbXNFJkAED5jckaYaG6lYkBxplOoQOaQHUnL9dYZf zZIHC39kem8PdsIPsCX3cVy6zuD7h/T3KnvU6RqZqKQGojvWg8D6o+UbF2XwdawobViZ rQ3w== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p1si7522648eds.205.2021.01.19.04.30.25; Tue, 19 Jan 2021 04:30:48 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391457AbhASLe3 (ORCPT + 99 others); Tue, 19 Jan 2021 06:34:29 -0500 Received: from outbound-smtp54.blacknight.com ([46.22.136.238]:53965 "EHLO outbound-smtp54.blacknight.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389823AbhASLXG (ORCPT ); Tue, 19 Jan 2021 06:23:06 -0500 Received: from mail.blacknight.com (pemlinmail03.blacknight.ie [81.17.254.16]) by outbound-smtp54.blacknight.com (Postfix) with ESMTPS id 2A7A3FB9F8 for ; Tue, 19 Jan 2021 11:22:12 +0000 (GMT) Received: (qmail 4584 invoked from network); 19 Jan 2021 11:22:12 -0000 Received: from unknown (HELO stampy.112glenside.lan) (mgorman@techsingularity.net@[84.203.22.4]) by 81.17.254.9 with ESMTPA; 19 Jan 2021 11:22:11 -0000 From: Mel Gorman To: Peter Zijlstra , Ingo Molnar Cc: Vincent Guittot , Li Aubrey , Qais Yousef , LKML , Mel Gorman Subject: [PATCH 1/5] sched/fair: Remove SIS_AVG_CPU Date: Tue, 19 Jan 2021 11:22:07 +0000 Message-Id: <20210119112211.3196-2-mgorman@techsingularity.net> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20210119112211.3196-1-mgorman@techsingularity.net> References: <20210119112211.3196-1-mgorman@techsingularity.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org SIS_AVG_CPU was introduced as a means of avoiding a search when the average search cost indicated that the search would likely fail. It was a blunt instrument and disabled by commit 4c77b18cf8b7 ("sched/fair: Make select_idle_cpu() more aggressive") and later replaced with a proportional search depth by commit 1ad3aaf3fcd2 ("sched/core: Implement new approach to scale select_idle_cpu()"). While there are corner cases where SIS_AVG_CPU is better, it has now been disabled for almost three years. As the intent of SIS_PROP is to reduce the time complexity of select_idle_cpu(), lets drop SIS_AVG_CPU and focus on SIS_PROP as a throttling mechanism. Signed-off-by: Mel Gorman Reviewed-by: Vincent Guittot --- kernel/sched/fair.c | 20 +++++++++----------- kernel/sched/features.h | 1 - 2 files changed, 9 insertions(+), 12 deletions(-) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index 04a3ce20da67..9f5682aeda2e 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -6145,7 +6145,6 @@ static int select_idle_cpu(struct task_struct *p, struct sched_domain *sd, int t { struct cpumask *cpus = this_cpu_cpumask_var_ptr(select_idle_mask); struct sched_domain *this_sd; - u64 avg_cost, avg_idle; u64 time; int this = smp_processor_id(); int cpu, nr = INT_MAX; @@ -6154,18 +6153,17 @@ static int select_idle_cpu(struct task_struct *p, struct sched_domain *sd, int t if (!this_sd) return -1; - /* - * Due to large variance we need a large fuzz factor; hackbench in - * particularly is sensitive here. - */ - avg_idle = this_rq()->avg_idle / 512; - avg_cost = this_sd->avg_scan_cost + 1; + if (sched_feat(SIS_PROP)) { + u64 avg_cost, avg_idle, span_avg; - if (sched_feat(SIS_AVG_CPU) && avg_idle < avg_cost) - return -1; + /* + * Due to large variance we need a large fuzz factor; + * hackbench in particularly is sensitive here. + */ + avg_idle = this_rq()->avg_idle / 512; + avg_cost = this_sd->avg_scan_cost + 1; - if (sched_feat(SIS_PROP)) { - u64 span_avg = sd->span_weight * avg_idle; + span_avg = sd->span_weight * avg_idle; if (span_avg > 4*avg_cost) nr = div_u64(span_avg, avg_cost); else diff --git a/kernel/sched/features.h b/kernel/sched/features.h index 68d369cba9e4..e875eabb6600 100644 --- a/kernel/sched/features.h +++ b/kernel/sched/features.h @@ -54,7 +54,6 @@ SCHED_FEAT(TTWU_QUEUE, true) /* * When doing wakeups, attempt to limit superfluous scans of the LLC domain. */ -SCHED_FEAT(SIS_AVG_CPU, false) SCHED_FEAT(SIS_PROP, true) /* -- 2.26.2