diff options
Diffstat (limited to 'arch/arm/mach-tegra/cpu-tegra.c')
-rw-r--r-- | arch/arm/mach-tegra/cpu-tegra.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/arch/arm/mach-tegra/cpu-tegra.c b/arch/arm/mach-tegra/cpu-tegra.c index b0163f0311b5..496a1582cd4f 100644 --- a/arch/arm/mach-tegra/cpu-tegra.c +++ b/arch/arm/mach-tegra/cpu-tegra.c @@ -105,15 +105,18 @@ static unsigned int edp_limit; static void edp_update_limit(void) { - int i; unsigned int limit = cpumask_weight(&edp_cpumask); if (!cpu_edp_limits) return; BUG_ON((edp_thermal_index >= cpu_edp_limits_size) || (limit == 0)); +#ifdef CONFIG_TEGRA_EDP_EXACT_FREQ + edp_limit = cpu_edp_limits[edp_thermal_index].freq_limits[limit - 1]; +#else limit = cpu_edp_limits[edp_thermal_index].freq_limits[limit - 1]; + int i; for (i = 0; freq_table[i].frequency != CPUFREQ_TABLE_END; i++) { if (freq_table[i].frequency > limit) { break; @@ -121,6 +124,7 @@ static void edp_update_limit(void) } BUG_ON(i == 0); /* min freq above the limit or table empty */ edp_limit = freq_table[i-1].frequency; +#endif } static unsigned int edp_governor_speed(unsigned int requested_speed) |