Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp545446ybl; Tue, 28 Jan 2020 07:39:23 -0800 (PST) X-Google-Smtp-Source: APXvYqwXDFCD6m+Mws5h2SuiELcZkInQWbP9tfrCFxJb59T5wghncYll7RnvNAhudGh0QylNAXnh X-Received: by 2002:a9d:7410:: with SMTP id n16mr17552416otk.23.1580225963388; Tue, 28 Jan 2020 07:39:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580225963; cv=none; d=google.com; s=arc-20160816; b=JqpycdmiV74wBwUwGyItI2sidHA5iQCLq3nwOJd0NwwNPdpeaINq28XB4aJq0pjsUI zdzi8gqmGJDeUzEcot1ACrpXEMcC4hhQSqn/n3hLTeq4A6LA9X2du3/2rdE05r51UWis 2c+F19FwCDUm0hxPvUOPDqOQr7pYzD/BEKfPvjcKipTavdBztr9S+ZHzvIyjSfyyd+Xz GBzp9/xqlUg14jYbZAzYqsvY0TX2ln9adRGoK11InbwDdQfSJsJq1NxC1w/JNdlXPhyo ladXpCjOCg1tYpszBbcc6T0mgplsvX/2pSW4MaMH8y9mUi+TPSiMPO4x9OP+fnGtjA2V l9iA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject; bh=ayncSgQ0WXm0iRWY/UK1f4bIXQdAxv1CI7ikspFQOcg=; b=Ge+y2uWXM9KMw0q7J0SzOYu2pLUO99zZww8wNc0uqv/hUJLstnog71cTWTZi0WC9MI MNMaZffPYvsAVpehrCXJars4DUCc48Tc7kBl3A/xi49H4zZ9ybEqZ++kPFAXnwVpfKgN bk4LKssIEZYKBGscN7V2ZOIYeMjE6I3DwV1hXGM186H/GWjfb0PPcQykCatIRkSPPY9k bhCWdBs3rpFyv9Kz/w98UBwb7CVx94JmPsApCS2MLntgBBsCEMHann0qgXjWWaPnbRcY 6o6xUoGCCyzpl8Sb6ZTzvW7m8mbBaTklOVuKyuLTdWHqfnaQOrNEBu1Ij0G51ObkV/cK W7/Q== 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 i140si5207624oib.90.2020.01.28.07.39.10; Tue, 28 Jan 2020 07:39:23 -0800 (PST) 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 S1726754AbgA1PiK (ORCPT + 99 others); Tue, 28 Jan 2020 10:38:10 -0500 Received: from foss.arm.com ([217.140.110.172]:59562 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726708AbgA1PiK (ORCPT ); Tue, 28 Jan 2020 10:38:10 -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 4304C31B; Tue, 28 Jan 2020 07:38:09 -0800 (PST) Received: from [10.1.195.43] (e107049-lin.cambridge.arm.com [10.1.195.43]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 0B7193F68E; Tue, 28 Jan 2020 07:38:07 -0800 (PST) Subject: Re: [RFC PATCH v4 4/6] sched/cpufreq: Introduce sugov_cpu_ramp_boost To: "Rafael J. Wysocki" Cc: Linux Kernel Mailing List , "Rafael J. Wysocki" , Viresh Kumar , Peter Zijlstra , Juri Lelli , Vincent Guittot , Dietmar Eggemann , qperret@google.com, Linux PM References: <20200122173538.1142069-1-douglas.raillard@arm.com> <20200122173538.1142069-5-douglas.raillard@arm.com> <9b5afae9-0cf5-6c3a-b94b-0796da4e6a71@arm.com> From: Douglas Raillard Organization: ARM Message-ID: Date: Tue, 28 Jan 2020 15:38:06 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.3.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-GB-large Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/23/20 9:02 PM, Rafael J. Wysocki wrote: > On Thu, Jan 23, 2020 at 6:21 PM Douglas Raillard > wrote: >> >> >> >> On 1/23/20 3:55 PM, Rafael J. Wysocki wrote: >>> On Wed, Jan 22, 2020 at 6:36 PM Douglas RAILLARD >>> wrote: >>>> >>>> Use the utilization signals dynamic to detect when the utilization of a >>>> set of tasks starts increasing because of a change in tasks' behavior. >>>> This allows detecting when spending extra power for faster frequency >>>> ramp up response would be beneficial to the reactivity of the system. >>>> >>>> This ramp boost is computed as the difference between util_avg and >>>> util_est_enqueued. This number somehow represents a lower bound of how >>>> much extra utilization this tasks is actually using, compared to our >>>> best current stable knowledge of it (which is util_est_enqueued). >>>> >>>> When the set of runnable tasks changes, the boost is disabled as the >>>> impact of blocked utilization on util_avg will make the delta with >>>> util_est_enqueued not very informative. >>>> >>>> Signed-off-by: Douglas RAILLARD >>>> --- >>>> kernel/sched/cpufreq_schedutil.c | 43 ++++++++++++++++++++++++++++++++ >>>> 1 file changed, 43 insertions(+) >>>> >>>> diff --git a/kernel/sched/cpufreq_schedutil.c b/kernel/sched/cpufreq_schedutil.c >>>> index 608963da4916..25a410a1ff6a 100644 >>>> --- a/kernel/sched/cpufreq_schedutil.c >>>> +++ b/kernel/sched/cpufreq_schedutil.c >>>> @@ -61,6 +61,10 @@ struct sugov_cpu { >>>> unsigned long bw_dl; >>>> unsigned long max; >>>> >>>> + unsigned long ramp_boost; >>>> + unsigned long util_est_enqueued; >>>> + unsigned long util_avg; >>>> + >>>> /* The field below is for single-CPU policies only: */ >>>> #ifdef CONFIG_NO_HZ_COMMON >>>> unsigned long saved_idle_calls; >>>> @@ -183,6 +187,42 @@ static void sugov_deferred_update(struct sugov_policy *sg_policy, u64 time, >>>> } >>>> } >>>> >>>> +static unsigned long sugov_cpu_ramp_boost(struct sugov_cpu *sg_cpu) >>>> +{ >>>> + return READ_ONCE(sg_cpu->ramp_boost); >>>> +} >>> >>> Where exactly is this function used? >> >> In the next commit where the boost value is actually used to do >> something. The function is introduced here to keep the >> WRITE_ONCE/READ_ONCE pair together. > > But ramp_boost itself is not really used in this patch too AFAICS. I'll squash that patch with the next one where it's actually used then: sched/cpufreq: Boost schedutil frequency ramp up Thanks, Douglas