diff options
author | Inderpal Singh <inderpal.singh@linaro.org> | 2012-03-05 10:27:08 +0530 |
---|---|---|
committer | Tushar Behera <tushar.behera@linaro.org> | 2012-06-20 11:12:32 +0530 |
commit | baf09a21800748e841ecec602a0b03fed5c12b13 (patch) | |
tree | fac5a43707b15d46e08a4dc79e1db032089f419e | |
parent | 6a5822da92b524e9bce175ecf010922046d1a5a0 (diff) |
[CPUFREQ] EXYNOS: Calculate old_index based on freqs.oldtracking-samslt-asv_cpufreq-ll-20120716.1tracking-samslt-asv_cpufreq-ll-20120716.0tracking-samslt-asv_cpufreq-ll-20120712.0tracking-samslt-asv_cpufreq-ll-20120711.0tracking-samslt-asv_cpufreq-ll-20120710.0tracking-samslt-asv_cpufreq-ll-20120627.0tracking-samslt-asv_cpufreq-ll-20120625.0tracking-samslt-asv_cpufreq-ll-20120622.0tracking-samslt-asv_cpufreq-ll-20120621.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.c | 11 |
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, |