From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-5.5 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id ED3B4C433E0 for ; Wed, 1 Jul 2020 13:35:07 +0000 (UTC) Received: from merlin.infradead.org (merlin.infradead.org [205.233.59.134]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id B82F220760 for ; Wed, 1 Jul 2020 13:35:07 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="DtEyVK/0" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org B82F220760 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=arm.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=merlin.20170209; h=Sender:Content-Transfer-Encoding: Content-Type:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References:Message-ID: Subject:To:From:Date:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=NYnMCtE8BHBCkG9D/C2WstiGiS+I+FKQCOOGfMAUxB8=; b=DtEyVK/0kCq2qYeqb0x6rHc0W 7JdDkZTIPiIs5xZHNsA1mCm1kCc0Kf2ouhHLqLBVS7E5E8mNr86S/lu2XpcdADaG4so+EEuqLrbz+ TiKksSwjEMhDdWannVaLkIDmK5a/IyXXODb0CqQ/9NRkw+6Kv78+y8D1OUb40tgJ3owg3IJwjtm74 YxpRpiphSviTV0amQ9dx4f+EkbLA9954kRWjaEQoERRvwRiD0ASUt9g1RaPNnmtN07wFkrMORNSwY q+wExYd+RjHAGtejKfexw9UdgL4xwXhQues9IM2X3w/X337Ygeyik+uvoNmm0DtykjRwNgP5aN4CK qqSHCDbZg==; Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1jqcro-0001DF-Me; Wed, 01 Jul 2020 13:33:37 +0000 Received: from foss.arm.com ([217.140.110.172]) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1jqcrl-000180-LQ for linux-arm-kernel@lists.infradead.org; Wed, 01 Jul 2020 13:33:34 +0000 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 67C6430E; Wed, 1 Jul 2020 06:33:32 -0700 (PDT) Received: from localhost (unknown [10.1.198.53]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 088733F73C; Wed, 1 Jul 2020 06:33:31 -0700 (PDT) Date: Wed, 1 Jul 2020 14:33:30 +0100 From: Ionela Voinescu To: Viresh Kumar Subject: Re: [PATCH 1/8] cpufreq: allow drivers to flag custom support for freq invariance Message-ID: <20200701133330.GA32736@arm.com> References: <20200701090751.7543-1-ionela.voinescu@arm.com> <20200701090751.7543-2-ionela.voinescu@arm.com> <20200701094417.ffuvduz6pqknjcks@vireshk-i7> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20200701094417.ffuvduz6pqknjcks@vireshk-i7> User-Agent: Mutt/1.9.4 (2018-02-28) X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200701_093333_777580_DE30A316 X-CRM114-Status: GOOD ( 22.48 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, peterz@infradead.org, catalin.marinas@arm.com, rjw@rjwysocki.net, linux@armlinux.org.uk, dietmar.eggemann@arm.com, mingo@redhat.com, sudeep.holla@arm.com, will@kernel.org, valentin.schneider@arm.com, linux-arm-kernel@lists.infradead.org Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org 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. > 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. 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. Thanks, Ionela. > -- > viresh _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel