cpufreq: kirkwood: use the powersave multiplexer
authorMike Turquette <mturquette@linaro.org>
Mon, 18 Aug 2014 15:30:29 +0000 (17:30 +0200)
committerMike Turquette <mturquette@linaro.org>
Tue, 2 Sep 2014 22:02:54 +0000 (15:02 -0700)
commit105299381d8720a3afd4252689ae8551f49944be
tree4978320975b50e6960af612cbeaab04bb48e549b
parente8e8a9b0d86c093b208789fd71501c91a919ffdb
cpufreq: kirkwood: use the powersave multiplexer

The powersave clock acts like a multiplexer for the cpu, selecting
either the clock signal derived from the cpu pll or from the ddr clock.
This patch changes powersave from a gate clock to a mux clock to better
reflect this behavior.

This is a cleaner approach whereby the frequency of the cpu always
matches the rate of powersave_clk. The cpufreq driver for the kirkwood
platform no longer must parse this behavior out of various calls to
clk_enable and clk_disable, but can instead simply select the parent cpu
it wants when changing rate. Likewise when requesting the cpu rate we
need only query powersave_clk's rate through the usual call to
clk_get_rate.

The new clock data and corresponding changes to the cpufreq driver are
combined into this single commit to avoid a git bisect issue where this
cpufreq driver fails to work properly between the commit that updates
the kirkwood clock driver and the commit that changes how the cpufreq
driver uses that clock.

Cc: Tomeu Vizoso <tomeu.vizoso@collabora.com>
Cc: Rafael J. Wysocki <rjw@rjwysocki.net>
Tested-by: Andrew Lunn <andrew@lunn.ch>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Mike Turquette <mturquette@linaro.org>
drivers/clk/mvebu/kirkwood.c
drivers/cpufreq/kirkwood-cpufreq.c