aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/clk
diff options
context:
space:
mode:
authorViresh Kumar <viresh.kumar@st.com>2012-04-11 06:33:42 -0400
committerMike Turquette <mturquette@linaro.org>2012-05-01 21:13:38 -0400
commit0e1c03017549a9df513622b3f15ff38eb8d35a62 (patch)
treef2fc7de20e598493916a27fbb7b6ba8104850a2f /drivers/clk
parent0197b3ea0f66cd2a11417f58fe1812858ea77908 (diff)
clk: clk_set_rate() must fail if CLK_SET_RATE_GATE is set and clk is enabled
This is well documented but isn't implemented. clk_set_rate() must check if flags have CLK_SET_RATE_GATE bit set and is enabled too. Signed-off-by: Viresh Kumar <viresh.kumar@st.com> Signed-off-by: Mike Turquette <mturquette@linaro.org>
Diffstat (limited to 'drivers/clk')
-rw-r--r--drivers/clk/clk.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
index c81803b9ba35..8149764f8438 100644
--- a/drivers/clk/clk.c
+++ b/drivers/clk/clk.c
@@ -900,6 +900,11 @@ int clk_set_rate(struct clk *clk, unsigned long rate)
900 if (rate == clk->rate) 900 if (rate == clk->rate)
901 goto out; 901 goto out;
902 902
903 if ((clk->flags & CLK_SET_RATE_GATE) && __clk_is_enabled(clk)) {
904 ret = -EBUSY;
905 goto out;
906 }
907
903 /* calculate new rates and get the topmost changed clock */ 908 /* calculate new rates and get the topmost changed clock */
904 top = clk_calc_new_rates(clk, rate); 909 top = clk_calc_new_rates(clk, rate);
905 if (!top) { 910 if (!top) {