From patchwork Thu Jul 27 19:33:04 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dietmar Eggemann X-Patchwork-Id: 108860 Delivered-To: patch@linaro.org Received: by 10.140.101.44 with SMTP id t41csp2486059qge; Thu, 27 Jul 2017 12:35:37 -0700 (PDT) X-Received: by 10.98.59.193 with SMTP id w62mr4979644pfj.335.1501184136952; Thu, 27 Jul 2017 12:35:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1501184136; cv=none; d=google.com; s=arc-20160816; b=jubwg4Q+RFjh8Nklj7VMFVAMHLE7Ywd5JGmZmZ37Hp3p0JYRaNwQ/oloaSWPDkx6rN FY56N1Xnm7nOQx2XUW4Z64CeGmOvQcBDI6by0NUZwLgp+oMLQ7skW1KUhyGT5lK/jfsR wrf8R/wJYvFcb7SR6BJjwgVXxwfphFp4KZFUVCpOUMcwNTBq55Pa3nuCol2Y9GSHAglX tAb9Rr4A1Db7aBgByIp39tng1rr41aDzkMWX3fLnxXRWLfPOMfVHmha2O/7oP+3EUv/7 s1qgyJ/4GJfWT2pncq2E4apkMmlHLRvujJsUz3/sOjYEu4X0rdjHt1F6H0Z1AOBmtsea VDYw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=YYSEunoAwqDIB5Fm8guZH6DRb0rjRYGm1wWRebB43Eg=; b=zK+vcH7TKOsXvtBE691MssLZ7QR6zZkIvxzr+kmcQW/eUX+TyPA9cGvgyE9eF/zIv3 IxgX+YL/zivCT1tUX1iODt0v/4T+8F/Ff7su83d7MptM+J1cZDCALmvfAqcEKszEtaiY FrEOUHZ5O9w3qfySzULoJ6YuDU1cA7XC4Q36G0CvUPDYCFMRy913WOypR/7zr2CeEvXB 1yNPYoJdAtCARmRSCDfgUVkj7+zcSuvGUyI4qCMzvXzxM+nck/JaPkDlU0XwzhCpQvWn oXzGc7tXI+lQqlyiVMZSpMA1fsR9tp871I+QKfX5nO9b/zFzNCPizfO7Z2RMyhkoNuuv BFrg== 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 n190si11241214pfn.600.2017.07.27.12.35.36; Thu, 27 Jul 2017 12:35:36 -0700 (PDT) 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 S1751754AbdG0Tdq (ORCPT + 26 others); Thu, 27 Jul 2017 15:33:46 -0400 Received: from foss.arm.com ([217.140.101.70]:51062 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751670AbdG0Tdm (ORCPT ); Thu, 27 Jul 2017 15:33:42 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 4613615A2; Thu, 27 Jul 2017 12:33:42 -0700 (PDT) Received: from e107985-lin.cambridge.arm.com (e107985-lin.cambridge.arm.com [10.1.210.41]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 0EC423F540; Thu, 27 Jul 2017 12:33:39 -0700 (PDT) From: Dietmar Eggemann To: linux-kernel@vger.kernel.org Cc: linux-pm@vger.kernel.org, linux@arm.linux.org.uk, Greg Kroah-Hartman , Russell King , Catalin Marinas , Will Deacon , Juri Lelli , Vincent Guittot , Peter Zijlstra , Morten Rasmussen , Viresh Kumar , "Rafael J . Wysocki" , Sudeep Holla Subject: [PATCH v3 02/10] cpufreq: provide default frequency-invariance setter function Date: Thu, 27 Jul 2017 20:33:04 +0100 Message-Id: <20170727193312.9849-3-dietmar.eggemann@arm.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20170727193312.9849-1-dietmar.eggemann@arm.com> References: <20170727193312.9849-1-dietmar.eggemann@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Frequency-invariant accounting support based on the ratio of current frequency and maximum supported frequency is an optional feature an arch can implement. Since there are cpufreq drivers (e.g. cpufreq-dt) which can be build for different arch's a default implementation of the frequency-invariance setter function arch_set_freq_scale() is needed. This default implementation is an empty weak function which will be overwritten by a strong function in case the arch provides one. The setter function passes the cpumask of related (to the frequency change) cpus (online and offline cpus), the (new) current frequency and the maximum supported frequency. Cc: Rafael J. Wysocki Cc: Viresh Kumar Signed-off-by: Dietmar Eggemann --- drivers/cpufreq/cpufreq.c | 11 +++++++++++ include/linux/cpufreq.h | 3 +++ 2 files changed, 14 insertions(+) -- 2.11.0 diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c index 9bf97a366029..04e2f7e4964e 100644 --- a/drivers/cpufreq/cpufreq.c +++ b/drivers/cpufreq/cpufreq.c @@ -2404,6 +2404,17 @@ int cpufreq_boost_enabled(void) EXPORT_SYMBOL_GPL(cpufreq_boost_enabled); /********************************************************************* + * FREQUENCY INVARIANT ACCOUNTING SUPPORT * + *********************************************************************/ + +__weak void arch_set_freq_scale(struct cpumask *cpus, + unsigned long cur_freq, + unsigned long max_freq) +{ +} +EXPORT_SYMBOL_GPL(arch_set_freq_scale); + +/********************************************************************* * REGISTER / UNREGISTER CPUFREQ DRIVER * *********************************************************************/ static enum cpuhp_state hp_online; diff --git a/include/linux/cpufreq.h b/include/linux/cpufreq.h index f10a9b3761cd..e38acc1a4d47 100644 --- a/include/linux/cpufreq.h +++ b/include/linux/cpufreq.h @@ -899,6 +899,9 @@ static inline bool policy_has_boost_freq(struct cpufreq_policy *policy) extern unsigned int arch_freq_get_on_cpu(int cpu); +extern void arch_set_freq_scale(struct cpumask *cpus, unsigned long cur_freq, + unsigned long max_freq); + /* the following are really really optional */ extern struct freq_attr cpufreq_freq_attr_scaling_available_freqs; extern struct freq_attr cpufreq_freq_attr_scaling_boost_freqs;