Locking in the clk API, part 2: clk_prepare/clk_unprepare

Jassi Brar jassisinghbrar at gmail.com
Fri Feb 4 06:04:03 EST 2011


On Fri, Feb 4, 2011 at 7:48 PM, Russell King - ARM Linux
<linux at arm.linux.org.uk> wrote:

> int clk_enable(struct clk *clk)
> {
>        unsigned long flags;
>        int ret = 0;
>
>        if (clk) {
>                if (WARN_ON(!clk->prepare_count))
>                        return -EINVAL;
>
>                spin_lock_irqsave(&clk->lock, flags);
>                if (clk->enable_count++ == 0)
>                        ret = clk->ops->enable(clk);
>                spin_unlock_irqrestore(&clk->lock, flags);
>        }
>        return ret;
> }
>
> is entirely sufficient to catch the case of a single-use clock not being
> prepared before clk_enable() is called.
>
> We're after detecting drivers missing calls to clk_prepare(), we're not
> after detecting concurrent calls to clk_prepare()/clk_unprepare().

I hope you mean 'making sure the clock is prepared before it's enabled
' rather than
'catching a driver that doesn't do clk_prepare before clk_enable'.
Because, the above implementation still doesn't catch a driver that
doesn't call clk_prepare
but simply uses a clock that happens to have been already prepare'd by
some other
driver or the platform.



More information about the linux-arm-kernel mailing list