summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--arch/arm/mach-tegra/cpu-tegra.c6
-rw-r--r--arch/arm/mach-tegra/tegra3_clocks.c11
2 files changed, 16 insertions, 1 deletions
diff --git a/arch/arm/mach-tegra/cpu-tegra.c b/arch/arm/mach-tegra/cpu-tegra.c
index fbca349a9fe4..afdec503f034 100644
--- a/arch/arm/mach-tegra/cpu-tegra.c
+++ b/arch/arm/mach-tegra/cpu-tegra.c
@@ -211,6 +211,10 @@ static int tegra_update_cpu_speed(unsigned long rate)
freqs.old = tegra_getspeed(0);
freqs.new = rate;
+ rate = clk_round_rate(cpu_clk, rate * 1000);
+ if (!IS_ERR_VALUE(rate))
+ freqs.new = rate / 1000;
+
if (freqs.old == freqs.new)
return ret;
@@ -218,7 +222,7 @@ static int tegra_update_cpu_speed(unsigned long rate)
* Vote on memory bus frequency based on cpu frequency
* This sets the minimum frequency, display or avp may request higher
*/
- clk_set_rate(emc_clk, tegra_emc_to_cpu_ratio(rate));
+ clk_set_rate(emc_clk, tegra_emc_to_cpu_ratio(freqs.new));
for_each_online_cpu(freqs.cpu)
cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE);
diff --git a/arch/arm/mach-tegra/tegra3_clocks.c b/arch/arm/mach-tegra/tegra3_clocks.c
index fa2f1e04de1a..b5cd2ecd3869 100644
--- a/arch/arm/mach-tegra/tegra3_clocks.c
+++ b/arch/arm/mach-tegra/tegra3_clocks.c
@@ -812,12 +812,23 @@ static int tegra3_cpu_cmplx_clk_set_parent(struct clk *c, struct clk *p)
return 0;
}
+static long tegra3_cpu_cmplx_round_rate(struct clk *c,
+ unsigned long rate)
+{
+ if (rate > c->parent->max_rate)
+ rate = c->parent->max_rate;
+ else if (rate < c->parent->min_rate)
+ rate = c->parent->min_rate;
+ return rate;
+}
+
static struct clk_ops tegra_cpu_cmplx_ops = {
.init = tegra3_cpu_cmplx_clk_init,
.enable = tegra3_cpu_cmplx_clk_enable,
.disable = tegra3_cpu_cmplx_clk_disable,
.set_rate = tegra3_cpu_cmplx_clk_set_rate,
.set_parent = tegra3_cpu_cmplx_clk_set_parent,
+ .round_rate = tegra3_cpu_cmplx_round_rate,
};
/* virtual cop clock functions. Used to acquire the fake 'cop' clock to