Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4070732pxu; Wed, 9 Dec 2020 07:40:55 -0800 (PST) X-Google-Smtp-Source: ABdhPJzN97NoWzWJpAm39JiblDRPf6N1zps3SDyc1If84fH54pKiV0vulfB0b79B5NSA+Htp6iQH X-Received: by 2002:aa7:cd9a:: with SMTP id x26mr2512225edv.226.1607528455058; Wed, 09 Dec 2020 07:40:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607528455; cv=none; d=google.com; s=arc-20160816; b=L0GemRhVBmU56pXqVzx/sGD+y3u9Pk2ArVWAVSIzJli6MZza3xDDxsGy904FVtTgtJ mLBr4Qvx++HdRSzJ/nVvsfjaJiVk3UOl8rrRwbr3hCb+znN085wK1AacdSuz+9umAKZT 61Y+Uflfc6y4y8rTViTYL82lt9NCQvT6qNSZk2IUhxw5Wt9fDsj1rh8iFOHN63MMLqHT ePcs7j2hyDrLBLjJF6vj5x4CKYe60CFmQmpNx/I6xfXVMm/+N4hoXIc4JfxbhKRA2an7 rFTDKPY7Nfyl8LPuCgkoKPcu3kWO24an6JUeCGrYDEnbKb/+eBEGAxLp8sFg6UjGGOVq cBrw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version; bh=ymMWquIrotxyInQP6qyo10dYrPww4c4U8Yy+Xq4TdD8=; b=JqZ6n5FWSzYfJHHSQhnd9ZdRgUNW/Q+7OJtB9KeWXXEkkcuZsb999bMe1fS8B4Etgk GkUCh3ya3fLe70ErTIxAg5EddtME/EbnpLuzx1rFrZ8R/W6w0gXdS1gqIN4YfPBFUQf/ es/Xq8oejYMzB0d3Nqh5Lvqnyi9pYitSaoAEom5fNCqaVsYO6Zya6O4e4xy1vc4G4jlE DYz+gaZhGNmugOUuA0zNyipm+HjMx3TfEplCgN40mMjx3t7RStF48w0a69gzOxmWlSgo 3fceBmk0ObpUpc4u4Tejv2zAI4TyCJA4D7Z/a3ISsRFXSHZHl/uPFPStzFNNYEMzKdE2 417Q== 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f12si944379ejk.142.2020.12.09.07.40.31; Wed, 09 Dec 2020 07:40:55 -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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728313AbgLIPc7 (ORCPT + 99 others); Wed, 9 Dec 2020 10:32:59 -0500 Received: from mail-oi1-f195.google.com ([209.85.167.195]:46767 "EHLO mail-oi1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726555AbgLIPc6 (ORCPT ); Wed, 9 Dec 2020 10:32:58 -0500 Received: by mail-oi1-f195.google.com with SMTP id k2so2074133oic.13; Wed, 09 Dec 2020 07:32:43 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ymMWquIrotxyInQP6qyo10dYrPww4c4U8Yy+Xq4TdD8=; b=tuL1Bf01S9IhQiclq+Ptcjt6GywSl4vv+hz7wJnfFBvmUZWi+cOKpSpm7MgPkGt5sq oUHq54fL8QDwqgsGbADtqnasxNpZtaiqUXYxTADhnX421PlUmg7bjCyrzYuOt6GIA2ri 41iD16OhJmBBCuj0Ox1ReG7n2vEPJ2pYoreW8VcB8FvQr0jN2lSI0lfu8Bwuqw+IMzN8 HKhb7qD5lN0vcUITlJRMA+b2sR+TpFMLfD/xkvSYTUzCfMdeZ98LV/qLa7UK8X7XXnC3 l/sM2YTQROR857ROw+kdiDK2qlskuj8h0aykUCGsWNjecck7bpnGFhpQQS4yaA9Nn2Xe Bpxw== X-Gm-Message-State: AOAM533Deilv4+Ej9q70BoZcabHS0/hmW5KAQRrHasIminO9JDTROwoR FiR+VQ1FEMgnPiKemE+q370Wz0m0gFlSbTqYQTW3oKLB X-Received: by 2002:aca:5197:: with SMTP id f145mr2150312oib.71.1607527937662; Wed, 09 Dec 2020 07:32:17 -0800 (PST) MIME-Version: 1.0 References: <20360841.iInq7taT2Z@kreacher> <1916732.tSaCp9PeQq@kreacher> <20201208085146.pzem6t3mt44xwxkm@vireshk-i7> <20201209051642.ddwgds4gznxt3lfn@vireshk-i7> In-Reply-To: <20201209051642.ddwgds4gznxt3lfn@vireshk-i7> From: "Rafael J. Wysocki" Date: Wed, 9 Dec 2020 16:32:06 +0100 Message-ID: Subject: Re: [PATCH v1 2/4] cpufreq: schedutil: Adjust utilization instead of frequency To: Viresh Kumar Cc: "Rafael J. Wysocki" , "Rafael J. Wysocki" , Linux PM , LKML , Srinivas Pandruvada , Peter Zijlstra , Doug Smythies , Giovanni Gherdovich Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Dec 9, 2020 at 6:16 AM Viresh Kumar wrote: > > On 08-12-20, 18:01, Rafael J. Wysocki wrote: > > On Tue, Dec 8, 2020 at 9:52 AM Viresh Kumar wrote: > > > > > > On 07-12-20, 17:29, Rafael J. Wysocki wrote: > > > > From: Rafael J. Wysocki > > > > > > > > When avoiding reduction of the frequency after the target CPU has > > > > been busy since the previous frequency update, adjust the utilization > > > > instead of adjusting the frequency, because doing so is more prudent > > > > (it is done to counter a possible utilization deficit after all) and > > > > it will allow some code to be shared after a subsequent change. > > > > > > > > Signed-off-by: Rafael J. Wysocki > > > > --- > > > > kernel/sched/cpufreq_schedutil.c | 11 ++++------- > > > > 1 file changed, 4 insertions(+), 7 deletions(-) > > > > > > > > Index: linux-pm/kernel/sched/cpufreq_schedutil.c > > > > =================================================================== > > > > --- linux-pm.orig/kernel/sched/cpufreq_schedutil.c > > > > +++ linux-pm/kernel/sched/cpufreq_schedutil.c > > > > @@ -437,7 +437,7 @@ static void sugov_update_single(struct u > > > > { > > > > struct sugov_cpu *sg_cpu = container_of(hook, struct sugov_cpu, update_util); > > > > struct sugov_policy *sg_policy = sg_cpu->sg_policy; > > > > - unsigned int cached_freq = sg_policy->cached_raw_freq; > > > > + unsigned long prev_util = sg_cpu->util; > > > > unsigned int next_f; > > > > > > > > sugov_iowait_boost(sg_cpu, time, flags); > > > > @@ -451,17 +451,14 @@ static void sugov_update_single(struct u > > > > sugov_get_util(sg_cpu); > > > > sugov_iowait_apply(sg_cpu, time); > > > > > > > > - next_f = get_next_freq(sg_policy, sg_cpu->util, sg_cpu->max); > > > > /* > > > > * Do not reduce the frequency if the CPU has not been idle > > > > * recently, as the reduction is likely to be premature then. > > > > */ > > > > - if (sugov_cpu_is_busy(sg_cpu) && next_f < sg_policy->next_freq) { > > > > - next_f = sg_policy->next_freq; > > > > + if (sugov_cpu_is_busy(sg_cpu) && sg_cpu->util < prev_util) > > > > + sg_cpu->util = prev_util; > > > > > > > > - /* Restore cached freq as next_freq has changed */ > > > > - sg_policy->cached_raw_freq = cached_freq; > > > > - } > > > > + next_f = get_next_freq(sg_policy, sg_cpu->util, sg_cpu->max); > > > > > > I don't think we can replace freq comparison by util, or at least it will give > > > us a different final frequency and the behavior is changed. > > > > > > Lets take an example, lets say current freq is 1 GHz and max is 1024. Ah, so that's in the freq-dependent case. In the freq-invariant case next_f doesn't depend on the current frequency. > > > Round 1: Lets say util is 1000 > > > > > > next_f = 1GHz * 1.25 * 1000/1024 = 1.2 GHz > > > > > > Round 2: Lets say util has come down to 900 here, > > > > > > before the patch: > > > > > > next_f = 1.2 GHz * 1.25 * 900/1024 = 1.31 GHz > > > > > > after the patch: > > > > > > next_f = 1.2 GHz * 1.25 * 1000/1024 = 1.45 GHz > > > > > > Or did I make a mistake here ? > > > > I think so, if my understanding is correct. > > > > Without the patch, next_f will be reset to the previous value > > (sq_policy->next_freq) if the CPU has been busy and the (new) next_f > > is less than that value. > > > > So the "new" next_f before the patch is 1.31 GHz, but because it is > > less than the previous value (1.45 GHz), it will be reset to that > > value, unless I'm missing something. > > The prev frequency here was 1.2 GHz (after Round 1). 1.45 GHz is the > value we get after this patch, as we take the earlier utilization > (1000) into account instead of 900. So I have misunderstood your example. In the non-invariant case (which is or shortly will be relevant for everybody interested) cpuinfo.max_freq goes into the calculation instead of the current frequency and the mapping between util and freq is linear. In the freq-dependent case it is not linear, of course. So I guess the concern is that this changes the behavior in the freq-dependent case which may not be desirable. Fair enough, but I'm not sure if that is enough of a reason to avoid sharing the code between the "perf" and "freq" paths.