summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorInderpal Singh <inderpal.singh@linaro.org>2012-03-05 10:27:08 +0530
committerTushar Behera <tushar.behera@linaro.org>2012-05-17 10:31:11 +0530
commitfd43b478a7679a31658300b047c38448dfc5ead8 (patch)
tree30c17a0afab18712badc8aec2c6ad671f8782bca
parent4ef63199581ccd2ec44d5dfdeb81a7ca75561111 (diff)
[CPUFREQ] EXYNOS: Calculate old_index based on freqs.oldtracking-samslt-asv_cpufreq-3.4-2012.05-1tracking-samslt-asv_cpufreq-3.4-2012.05-0
Do not calculate old_index with cpufreq_frequency_table_target because it won't give the correct old_index if the policy got changed. Hence, use freqs.old to calculate old_index. Signed-off-by: Inderpal Singh <inderpal.singh@linaro.org> Signed-off-by: Tushar Behera <tushar.behera@linaro.org>
-rw-r--r--drivers/cpufreq/exynos-cpufreq.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/cpufreq/exynos-cpufreq.c b/drivers/cpufreq/exynos-cpufreq.c
index 749be588c415..1ff48a4526b3 100644
--- a/drivers/cpufreq/exynos-cpufreq.c
+++ b/drivers/cpufreq/exynos-cpufreq.c
@@ -48,7 +48,7 @@ static int exynos_target(struct cpufreq_policy *policy,
unsigned int target_freq,
unsigned int relation)
{
- unsigned int index, old_index;
+ unsigned int index, old_index = 0, i;
unsigned int arm_volt, safe_arm_volt = 0;
int ret = 0;
struct cpufreq_frequency_table *freq_table = exynos_info->freq_table;
@@ -64,10 +64,11 @@ static int exynos_target(struct cpufreq_policy *policy,
goto out;
}
- if (cpufreq_frequency_table_target(policy, freq_table,
- freqs.old, relation, &old_index)) {
- ret = -EINVAL;
- goto out;
+ for (i = 0; (freq_table[i].frequency != CPUFREQ_TABLE_END); i++) {
+ if (freqs.old == freq_table[i].frequency) {
+ old_index = i;
+ break;
+ }
}
if (cpufreq_frequency_table_target(policy, freq_table,