Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp749233ybt; Wed, 1 Jul 2020 09:06:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyH50eifSk5/UELdZFzZ6sHQ5KAoIEDQB7dFasiasNYLFy5MpKHLYOVkoaluC1sLWzQf7e/ X-Received: by 2002:a50:e408:: with SMTP id d8mr29189204edm.375.1593619584993; Wed, 01 Jul 2020 09:06:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593619584; cv=none; d=google.com; s=arc-20160816; b=IkKLmajJqp2fCbIfcR0kq+xcDp+b1tar0iJliXqbw9oH7BlGPM6pAnwf9/G4VTMMZd WBqWGqBVZZH/Cxnr1iqXFlAOqix2adMYIFaayO3YurYrAhjbitSik/107VPGhvdEaOGJ aaZx6fyN3ALIOys5YHkojR4KxkmRTw93aHAwGQaFoI+DsTpvEeIYqbdSD4ox0KK/5SDi HKMYzQF3Bmx0bbtogGshptpuWOL7MWNq7DB3Zim1+A5gwJsBxRM2Pef2HzXv6+gckRBU 5poHBu1DAYZFIhgJpqt/0Z8Z25M1v20G+qZ5ERGl8LZ0YVrQaFUKE3yfsyh3fnir6Vbn 72yQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version; bh=x+roH6OrPDt51jxgNFtZVZqDRGVI2e47jOLKRXACWd4=; b=lR903r+5iVkL1wZpgxb6D9cyIwo7DHT41Z+1ha65wdmnGAsGrcAoNjFYAQbGo4rodk q6oUwuHjyoM/tHAiLt3oJiQiGIeyXfhf1PbZRx4slMzdJdRu4fmH+Nrm8+fPsx9Z31TC 6e58oOFUQ9Nyp7KMW5ZwwWfqdgG8SaqhoNDW5Uc4ky2wPPuzmA1I3jYeMFi0no9H5LCF ZSAWOiJZUY8EpgRv0SneGT2aQGJS8n/zH5ibIOOnCs6bxTUhZqvRJVTXTSKcAl2kOl7C FeC0GGAozQfLX2OJu/cOr1kmdFdpV+9XHPIwr5DWmh4DjMvlGDStLPg0coY9S9gYnIOq 8FHw== 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 bx7si4035258edb.150.2020.07.01.09.06.01; Wed, 01 Jul 2020 09:06:24 -0700 (PDT) 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 S1732257AbgGAQFp (ORCPT + 99 others); Wed, 1 Jul 2020 12:05:45 -0400 Received: from mail-ot1-f66.google.com ([209.85.210.66]:44603 "EHLO mail-ot1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726506AbgGAQFp (ORCPT ); Wed, 1 Jul 2020 12:05:45 -0400 Received: by mail-ot1-f66.google.com with SMTP id 5so19806163oty.11; Wed, 01 Jul 2020 09:05:44 -0700 (PDT) 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=x+roH6OrPDt51jxgNFtZVZqDRGVI2e47jOLKRXACWd4=; b=fuQMihO5n1KpIYJM3DIXOJzcmsBMb1hlul6Bp0XYkGtgHwPcSEbdnHitqYU9ySEK/O lVBgd/amo+9WudVtKl6/I1LaWwjBj0FD0cz3C0aVflVzKzFPNTiAURRXyi0VMrE/efzs /c2uxY34JMmkPfpt9sj4gUvy8Izrd19NNSWsCTXCETqq1frWSFYS/q5al2IBrCMDqspE jPMuDQl/UeE04HgqClkF5By7Wznykvt3ot20xdtB79wAKX06Sa7i+ib08ULSJSEt/o0e iVxrZ/8gJ4IRkzuMzsMhbGLdhBr7wfSWyPkyt1S0ThxnPDKh54b0vhPqLtwgY/kXeusB 2rvQ== X-Gm-Message-State: AOAM533oxFJSI3/QVTiWsRjgNKnINv8YDgpC8S1jVYzr7NGXRrzYtYiR 31fYAPrb8kwL8FLsPdd/Gpe+hAd2JQXQ73JeugM= X-Received: by 2002:a05:6830:30ba:: with SMTP id g26mr2092984ots.118.1593619544373; Wed, 01 Jul 2020 09:05:44 -0700 (PDT) MIME-Version: 1.0 References: <20200701090751.7543-1-ionela.voinescu@arm.com> <20200701090751.7543-2-ionela.voinescu@arm.com> <20200701094417.ffuvduz6pqknjcks@vireshk-i7> <20200701133330.GA32736@arm.com> In-Reply-To: <20200701133330.GA32736@arm.com> From: "Rafael J. Wysocki" Date: Wed, 1 Jul 2020 18:05:33 +0200 Message-ID: Subject: Re: [PATCH 1/8] cpufreq: allow drivers to flag custom support for freq invariance To: Ionela Voinescu Cc: Viresh Kumar , "Rafael J. Wysocki" , Catalin Marinas , Sudeep Holla , Will Deacon , Russell King - ARM Linux , Valentin Schneider , Ingo Molnar , Peter Zijlstra , Dietmar Eggemann , Linux PM , Linux ARM , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jul 1, 2020 at 3:33 PM Ionela Voinescu wrote: > > Hi, > > Thank you for taking a look over these so quickly. > > On Wednesday 01 Jul 2020 at 16:16:17 (+0530), Viresh Kumar wrote: > > On 01-07-20, 10:07, Ionela Voinescu wrote: > > > diff --git a/include/linux/cpufreq.h b/include/linux/cpufreq.h > > > index 3494f6763597..42668588f9f8 100644 > > > --- a/include/linux/cpufreq.h > > > +++ b/include/linux/cpufreq.h > > > @@ -293,7 +293,7 @@ __ATTR(_name, 0644, show_##_name, store_##_name) > > > > > > struct cpufreq_driver { > > > char name[CPUFREQ_NAME_LEN]; > > > - u8 flags; > > > + u16 flags; > > > > Lets make it u32. > > > > > void *driver_data; > > > > > > /* needed by all drivers */ > > > @@ -417,6 +417,14 @@ struct cpufreq_driver { > > > */ > > > #define CPUFREQ_IS_COOLING_DEV BIT(7) > > > > > > +/* > > > + * Set by drivers which implement the necessary calls to the scheduler's > > > + * frequency invariance engine. The use of this flag will result in the > > > + * default arch_set_freq_scale calls being skipped in favour of custom > > > + * driver calls. > > > + */ > > > +#define CPUFREQ_CUSTOM_SET_FREQ_SCALE BIT(8) > > > > I will rather suggest CPUFREQ_SKIP_SET_FREQ_SCALE as the name and > > functionality. We need to give drivers a choice if they do not want > > the core to do it on their behalf, because they are doing it on their > > own or they don't want to do it. Well, this would go backwards to me, as we seem to be designing an opt-out flag for something that's not even implemented already. I would go for an opt-in instead. That would be much cleaner and less prone to regressions IMO. > > In this case we would not be able to tell if cpufreq (driver or core) > can provide the frequency scale factor, so we would not be able to tell > if the system is really frequency invariant; CPUFREQ_SKIP_SET_FREQ_SCALE > would be set if either: > - the driver calls arch_set_freq_scale() on its own > - the driver does not want arch_set_freq_scale() to be called. > > So at the core level we would not be able to distinguish between the > two, and return whether cpufreq-based invariance is supported. > > I don't really see a reason why a driver would not want to set the > frequency scale factor, if it has the proper mechanisms to do so > (therefore excluding the exceptions mentioned in 2/8). I think the > cpufreq core or drivers should produce the information (set the scale > factor) and it should be up to the users to decide whether to use it or > not. But being invariant should always be the default. So instead of what is being introduced by this patch, there should be an opt-in mechanism for drivers to tell the core to do the freq-scale factor setting on behalf of the driver. Then, the driver would be responsible to only opt-in for that if it knows it for a fact that the sched tick doesn't set the freq-scale factor. > Therefore, there are a few reasons I went for > CPUFREQ_CUSTOM_SET_FREQ_SCALE instead: > - It tells us if the driver has custom mechanisms to set the scale > factor to filter the setting in cpufreq core and to inform the > core on whether the system is frequency invariant. > - It does have a user in the vexpress-spc driver. > - Currently there aren't drivers that could but choose not to set > the frequency scale factor, and it my opinion this should not be > the case. Well, that depends on what you mean by "could". For example, it doesn't really make sense to set the freq-scale factor in either the ACPI cpufreq driver or intel_pstate, because the frequency (or P-state to be precise) requested by them may not be the one the CPU ends up running at and even so it may change at any time for various reasons (eg. in the turbo range). However, the ACPI cpufreq driver as well as intel_pstate in the passive mode both set policy->cur, so that might be used for setting the freq-scale factor in principle, but that freq-scale factor may not be very useful in practice. Thanks!