From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756817Ab3GDPSX (ORCPT ); Thu, 4 Jul 2013 11:18:23 -0400 Received: from mailout1.w1.samsung.com ([210.118.77.11]:8414 "EHLO mailout1.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756794Ab3GDPR7 (ORCPT ); Thu, 4 Jul 2013 11:17:59 -0400 X-AuditID: cbfec7f5-b7f376d000001ec6-ff-51d5922634f0 From: Konstantin Krivyakin To: k.krivyakin@samsung.com, i.zhbanov@samsung.com, e.voevodin@samsung.com, kyungmin.park@samsung.com, linux-kernel@vger.kernel.org Subject: [PATCH RFC 3/3] Update current cpu power when cpu freq change for exynos. Date: Thu, 04 Jul 2013 19:17:19 +0400 Message-id: <1372951039-10375-4-git-send-email-k.krivyakin@samsung.com> X-Mailer: git-send-email 1.7.9.5 In-reply-to: <1372951039-10375-1-git-send-email-k.krivyakin@samsung.com> References: <1372951039-10375-1-git-send-email-k.krivyakin@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrPJMWRmVeSWpSXmKPExsVy+t/xa7pqk64GGuxbJ2Kx9lw7k8WKq0cY LaYuPMxucbbpDbvF5V1z2BxYPfq2rGL0+LxJLoApissmJTUnsyy1SN8ugStj1/WbLAUrhCsW /ZrH1sC4QaCLkZNDQsBEYk/LZDYIW0ziwr31QDYXh5DAUkaJTZvPsoIkhAS6mSROdYSA2GxA Dbv3XmQGKRIRaGWUaH3VBdYtLBAi0b/pAJjNIqAq8ej1MxYQm1fAXeLPy73sXYwcQBsUJOZM sgExOQU8JOYt5IIY7y7R+ms9+wRGngWMDKsYRVNLkwuKk9JzjfSKE3OLS/PS9ZLzczcxQgLh 6w7GpcesDjEKcDAq8fA+rL8aKMSaWFZcmXuIUYKDWUmE91QzUIg3JbGyKrUoP76oNCe1+BAj EwenVAPjpGqFq4p/Ir4IGE9ZtnazkUwF/3HWjnWq5W71adEfQ5bp+IkbCfBEcHaHSLx9x/pI 5qH76zmH15hN2FxwT+nZq5tS7+c9Lt6uZNlhdTx9RYRT36L8wBvVkXE6XZui1zce/q1dZhvy 8PaL+TJOm37Okf+6/bd0ty+rWpH43thtshuiahdtKDiqxFKckWioxVxUnAgABd6Y8eIBAAA= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Signed-off-by: Konstantin Krivyakin --- drivers/cpufreq/exynos-cpufreq.c | 2 ++ drivers/cpufreq/exynos-cpufreq.h | 1 + drivers/cpufreq/exynos4x12-cpufreq.c | 19 ++++++++++++++++++- 3 files changed, 21 insertions(+), 1 deletion(-) diff --git a/drivers/cpufreq/exynos-cpufreq.c b/drivers/cpufreq/exynos-cpufreq.c index 0d32f02..02f17bc 100644 --- a/drivers/cpufreq/exynos-cpufreq.c +++ b/drivers/cpufreq/exynos-cpufreq.c @@ -178,6 +178,8 @@ static int exynos_target(struct cpufreq_policy *policy, } new_freq = freq_table[index].frequency; + if (exynos_info->power_table) + policy->current_power = exynos_info->power_table[index]; ret = exynos_cpufreq_scale(new_freq); diff --git a/drivers/cpufreq/exynos-cpufreq.h b/drivers/cpufreq/exynos-cpufreq.h index 92b852e..64f964f 100644 --- a/drivers/cpufreq/exynos-cpufreq.h +++ b/drivers/cpufreq/exynos-cpufreq.h @@ -38,6 +38,7 @@ struct exynos_dvfs_info { unsigned int pll_safe_idx; struct clk *cpu_clk; unsigned int *volt_table; + u64 *power_table; struct cpufreq_frequency_table *freq_table; void (*set_freq)(unsigned int, unsigned int); bool (*need_apll_change)(unsigned int, unsigned int); diff --git a/drivers/cpufreq/exynos4x12-cpufreq.c b/drivers/cpufreq/exynos4x12-cpufreq.c index 08b7477..8905f9b 100644 --- a/drivers/cpufreq/exynos4x12-cpufreq.c +++ b/drivers/cpufreq/exynos4x12-cpufreq.c @@ -219,6 +219,7 @@ static void exynos4x12_set_frequency(unsigned int old_index, int exynos4x12_cpufreq_init(struct exynos_dvfs_info *info) { unsigned long rate; + int freq_count; cpu_clk = clk_get(NULL, "armclk"); if (IS_ERR(cpu_clk)) @@ -252,8 +253,24 @@ int exynos4x12_cpufreq_init(struct exynos_dvfs_info *info) info->set_freq = exynos4x12_set_frequency; info->need_apll_change = exynos4x12_pms_change; - return 0; + freq_count = sizeof(exynos4x12_freq_table) / + sizeof(struct cpufreq_frequency_table); + info->power_table = kzalloc(sizeof(u64) * freq_count, GFP_KERNEL); + if (!info->power_table) + goto err_power_table; + + for (i = 0; i <= freq_count; ++i) { + u64 freq = info->freq_table[i].frequency; + u64 volt = info->volt_table[i]; + do_div(freq, 1000); + do_div(volt, 1000); + info->power_table[i] = freq * volt * volt; + } + + return 0; +err_power_table: + clk_put(mout_appl); err_mout_apll: clk_put(mout_mpll); err_mout_mpll: -- 1.7.9.5