sh: call clock framework init() callback once
authorMagnus Damm <damm@igel.co.jp>
Thu, 7 May 2009 10:31:39 +0000 (10:31 +0000)
committerPaul Mundt <lethal@linux-sh.org>
Fri, 8 May 2009 02:38:28 +0000 (11:38 +0900)
Make sure that clk->ops->init() only gets called once in
the case of CLK_ALWAYS_ENABLED. Without this patch the
init() callback may be called multiple times.

Signed-off-by: Magnus Damm <damm@igel.co.jp>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/kernel/cpu/clock.c

index 1dc896483b591169bcf1254b70e4961ed3e88337..099373ae57d840f8cb6a16f9af5e4778727855aa 100644 (file)
@@ -99,15 +99,18 @@ static int __clk_enable(struct clk *clk)
         * changes and the clock needs to hunt for the proper set of
         * divisors to use before it can effectively recalc.
         */
+
+       if (clk->flags & CLK_ALWAYS_ENABLED) {
+               kref_get(&clk->kref);
+               return 0;
+       }
+
        if (unlikely(atomic_read(&clk->kref.refcount) == 1))
                if (clk->ops && clk->ops->init)
                        clk->ops->init(clk);
 
        kref_get(&clk->kref);
 
-       if (clk->flags & CLK_ALWAYS_ENABLED)
-               return 0;
-
        if (likely(clk->ops && clk->ops->enable))
                clk->ops->enable(clk);