From patchwork Tue Aug 20 16:35:09 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Qais Yousef X-Patchwork-Id: 13770474 Received: from mail-ej1-f43.google.com (mail-ej1-f43.google.com [209.85.218.43]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F00B91C0DCA for ; Tue, 20 Aug 2024 16:36:51 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.218.43 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1724171813; cv=none; b=W5PiwPlKcJotDQeTtY/94Unf/36thZyw3E+gjEhxHd75p84UkWfUAsXmdr0usb0Qa6KQakZKEQBFY5NEpYYovFYs3i8NWbHYGeur8PTpxGI96GSna38Pwu4Oj0mAdKNiJXRaQRzZNk5yC7BUv2caRj4yBJeKEk7arFBrEuTCWMo= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1724171813; c=relaxed/simple; bh=peGOTrMpJU6Y/7bYHyR4tSGHI6Lbtst36QPON3uOXj0=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=WlnjVwzx01eSgUlJhJPpXeLmmLnHl8B9SyPdGn9GNYdFadLhXGN+XHh1gULbnCOpT+lRMc0fK/Otpot96z6oc1VfgrgKzw6QB6phAB4i/O98+SWaX/x7T/9Vh/+0nKLUTT7of1jkBif9tEnUJF6SuME3jqfNpe1fHVtQrl9vcfo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=layalina.io; spf=pass smtp.mailfrom=layalina.io; dkim=pass (2048-bit key) header.d=layalina-io.20230601.gappssmtp.com header.i=@layalina-io.20230601.gappssmtp.com header.b=3A3uUyoa; arc=none smtp.client-ip=209.85.218.43 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=layalina.io Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=layalina.io Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=layalina-io.20230601.gappssmtp.com header.i=@layalina-io.20230601.gappssmtp.com header.b="3A3uUyoa" Received: by mail-ej1-f43.google.com with SMTP id a640c23a62f3a-a8647056026so125241366b.0 for ; Tue, 20 Aug 2024 09:36:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=layalina-io.20230601.gappssmtp.com; s=20230601; t=1724171810; x=1724776610; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=nawo0iXyk8rugawGjPThZSFWb4byKstZYwvxJoh01/U=; b=3A3uUyoa2XVh8IQpUMWF9oo+EJnAtvGnVkgTOkd3SrhbRtIYlpsyGX8V8H0KcR/V1e nC3fH2Ff2pHhFdNpRiGMeGkoOLXJJ3ZVk4/EDrag/Ntp/+MGPqI7avbvbJDjJjbxxTPg lzc0t5Agrk7BhTMPRV3uFnEnFfmr9nLTrrUJP5okbQOVen/wZpjKsrHUhEPuIHUCDEJE 3uapYNNelcMfaAL2Lb+dTBqsLyUESbDBWE47bOvfOOznohFRNZ8BkOduG711d+zvGaf7 FoDW+9myWedFeQHli9yAucsOfnybJAoZ/G8ZUmlROJcvzHe4zoCdGL7ccOb1BtYf75LJ FFJQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1724171810; x=1724776610; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=nawo0iXyk8rugawGjPThZSFWb4byKstZYwvxJoh01/U=; b=EKO6BKHa14pM7q71gS3LkRdyDqcsYISEV3Nn6A5RM5+pDou6iMNhBYSjd/zFiGtyyG oLddjHZOn86E1BmIm8VMxDvp41llEnfVKCSUVfAkjQAgJqsyuppOkQWwFM4MY6VYrmiM Tt2DfGBvgFrfLMc1FvAdRSA2qb8iA0h0k2DcWjN8o27v1bKmfwcQAH/WzVEj8rqePLE5 jWtvJgw/VTe93wUaLlhtRCVGhl3YsQcA2FgA6ijEk10PWIkuTiVkzpyrpqQGOEyL88vZ jFm6HMkm7TbiPcxtQYSxBlc21cdIgdYzTSNOLnteHZN9pnmTp3Xfp5tBBqRVMZPgw+DX VvCg== X-Forwarded-Encrypted: i=1; AJvYcCV3NhACOj1bw6RSLUFlYsofGMIwhupnhcCQyLwy3Sh5VePjWIWZDegMks0PqFzv+/gIYDhpdibCIA==@vger.kernel.org X-Gm-Message-State: AOJu0Yww0VG48dURrqKa1GaG3UV2qQePzhYY8MiG0wmtsBYt4UI5WAIk uA8rciXirJw3mxkzGJB9ivHGr+DJPdAUgG7jU54vFZ+J8EQ484DX/Ue07szdYVM= X-Google-Smtp-Source: AGHT+IGIadSEibAssyW3zb8AhXXDHexQCIIATFiI9hph0UEKoDLXeaAbkr5C1JABp/pKbDbwR99llQ== X-Received: by 2002:a17:907:d3c9:b0:a7a:b643:654f with SMTP id a640c23a62f3a-a839292f3ccmr1052502366b.15.1724171810258; Tue, 20 Aug 2024 09:36:50 -0700 (PDT) Received: from airbuntu.. (host81-157-90-255.range81-157.btcentralplus.com. [81.157.90.255]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-a83838cfb5esm780728766b.59.2024.08.20.09.36.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 20 Aug 2024 09:36:49 -0700 (PDT) From: Qais Yousef To: Ingo Molnar , Peter Zijlstra , Vincent Guittot , "Rafael J. Wysocki" , Viresh Kumar Cc: Juri Lelli , Steven Rostedt , Dietmar Eggemann , John Stultz , linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, Qais Yousef Subject: [RFC PATCH 13/16] sched/schedutil: Take into account waiting_avg in apply_dvfs_headroom Date: Tue, 20 Aug 2024 17:35:09 +0100 Message-Id: <20240820163512.1096301-14-qyousef@layalina.io> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240820163512.1096301-1-qyousef@layalina.io> References: <20240820163512.1096301-1-qyousef@layalina.io> Precedence: bulk X-Mailing-List: linux-pm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 We now have three sources of delays. 1. How often we send cpufreq_updates 2. How often we update util_avg 3. How long tasks wait in RUNNABLE to become RUNNING The headroom should cater for all this type of delays to ensure the system is running at adequate performance point. We want to pick the maximum headroom required by any of these sources of delays. TODO: the signal should use task clock not pelt as this should be real time based and we don't care about invariance. Signed-off-by: Qais Yousef --- kernel/sched/cpufreq_schedutil.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/kernel/sched/cpufreq_schedutil.c b/kernel/sched/cpufreq_schedutil.c index 94e35b7c972d..318b09bc4ab1 100644 --- a/kernel/sched/cpufreq_schedutil.c +++ b/kernel/sched/cpufreq_schedutil.c @@ -259,10 +259,15 @@ static unsigned int get_next_freq(struct sugov_policy *sg_policy, * dvfs_update_delay of the cpufreq governor or min(curr.se.slice, TICK_US), * whichever is higher. * + * Also take into accounting how long tasks have been waiting in runnable but + * !running state. If it is high, it means we need higher DVFS headroom to + * reduce it. + * * XXX: Should we provide headroom when the util is decaying? */ static inline unsigned long sugov_apply_dvfs_headroom(unsigned long util, int cpu) { + unsigned long update_headroom, waiting_headroom; struct rq *rq = cpu_rq(cpu); u64 delay; @@ -276,7 +281,10 @@ static inline unsigned long sugov_apply_dvfs_headroom(unsigned long util, int c delay = TICK_USEC; delay = max(delay, per_cpu(dvfs_update_delay, cpu)); - return approximate_util_avg(util, delay); + update_headroom = approximate_util_avg(util, delay); + waiting_headroom = util + READ_ONCE(rq->cfs.avg.waiting_avg); + + return max(update_headroom, waiting_headroom); } unsigned long sugov_effective_cpu_perf(int cpu, unsigned long actual,