Re: [RFC v2 1/1] clk: Add notifier support inclk_prepare/clk_unprepare

From: Bill Huang
Date: Thu Mar 14 2013 - 05:47:02 EST


On Thu, 2013-03-14 at 17:31 +0800, Bill Huang wrote:
> Add the below two notifier events so drivers which are interested in
> knowing the clock status can act accordingly. This is extremely useful
> in some of the DVFS (Dynamic Voltage Frequency Scaling) design.
>
> CLK_PREPARED
> CLK_UNPREPARED
>
> Signed-off-by: Bill Huang <bilhuang@xxxxxxxxxx>
> ---
> drivers/clk/clk.c | 3 +++
> include/linux/clk.h | 2 ++
> 2 files changed, 5 insertions(+)
>
> diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
> index ed87b24..3292cec 100644
> --- a/drivers/clk/clk.c
> +++ b/drivers/clk/clk.c
> @@ -550,6 +550,7 @@ void clk_unprepare(struct clk *clk)
> {
> mutex_lock(&prepare_lock);
> __clk_unprepare(clk);
> + __clk_notify(clk, CLK_UNPREPARED, clk->rate, clk->rate);
> mutex_unlock(&prepare_lock);
> }
> EXPORT_SYMBOL_GPL(clk_unprepare);
> @@ -598,6 +599,8 @@ int clk_prepare(struct clk *clk)
>
> mutex_lock(&prepare_lock);
> ret = __clk_prepare(clk);
> + if (!ret)
> + __clk_notify(clk, CLK_PREPARED, clk->rate, clk->rate);
> mutex_unlock(&prepare_lock);
>
> return ret;
> diff --git a/include/linux/clk.h b/include/linux/clk.h
> index b3ac22d..16c1d92 100644
> --- a/include/linux/clk.h
> +++ b/include/linux/clk.h
> @@ -43,6 +43,8 @@ struct clk;
> #define PRE_RATE_CHANGE BIT(0)
> #define POST_RATE_CHANGE BIT(1)
> #define ABORT_RATE_CHANGE BIT(2)
> +#define CLK_PREPARED BIT(3)
> +#define CLK_UNPREPARED BIT(4)
>
> /**
> * struct clk_notifier - associate a clk with a notifier
Sorry, I'll send v3 since this bread build.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/