[PATCH] clk: gate: add CLK_GATE_ALWAYS_ON

Viresh Kumar viresh.kumar at linaro.org
Tue Aug 6 00:45:56 EDT 2013


Added linaro-kernel & patches at linaro.org in cc list..

On 6 August 2013 09:27, Shaojie Sun <shaojie.sun at linaro.org> wrote:
> By default gate clock could be enable and disable. but
> in some debug condition, must keep clock on, and never be closed.
> setting this flag then gate clock never be closed.

Consider rewriting it as:

By default gate clk can be enabled/disabled but during debugging we
may want to disable clk-disabling feature.

This patch adds a flag for it..

> Signed-off-by: Shaojie Sun <shaojie.sun at linaro.com>
> ---
>  drivers/clk/clk-gate.c       |   24 ++++++++++++++++++++++++
>  include/linux/clk-provider.h |    4 ++++
>  2 files changed, 28 insertions(+)

Honestly speaking, I am not sure if this patch is really required or not.
And so Mike can decide on that. I will do a simple code review in
that time.

> diff --git a/drivers/clk/clk-gate.c b/drivers/clk/clk-gate.c
> index 790306e..cc2b00e 100644
> --- a/drivers/clk/clk-gate.c
> +++ b/drivers/clk/clk-gate.c
> @@ -15,6 +15,7 @@
>  #include <linux/io.h>
>  #include <linux/err.h>
>  #include <linux/string.h>
> +#include <linux/device.h>

why?

>  /**
>   * DOC: basic gatable clock which can gate and ungate it's ouput
> @@ -48,6 +49,9 @@ static void clk_gate_endisable(struct clk_hw *hw, int enable)
>         unsigned long flags = 0;
>         u32 reg;
>
> +       if (!enable && (gate->flags & CLK_GATE_ALWAYS_ON))
> +               return;
> +
>         set ^= enable;
>
>         if (gate->lock)
> @@ -159,5 +163,25 @@ struct clk *clk_register_gate(struct device *dev, const char *name,
>         if (IS_ERR(clk))
>                 kfree(gate);
>
> +       if (clk_gate_flags & CLK_GATE_ALWAYS_ON) {
> +               int ret;
> +               if (flags & CLK_SET_PARENT_GATE)
> +                       pr_debug("%s: %salways on, but need parent gate.\n",
> +                                       __func__, name);
> +
> +               ret = clk_prepare(clk);
> +               if (ret) {
> +                       pr_debug("%s: %s could not be prepared.\n",
> +                                       __func__, name);
> +                       return clk;
> +               }
> +               ret = clk_enable(clk);
> +               if (ret) {
> +                       pr_debug("%s: %s could not be enabled.\n",
> +                                       __func__, name);
> +                       clk_unprepare(clk);
> +               }

Call clk_prepare_enable instead.

> +       }
> +
>         return clk;
>  }
> diff --git a/include/linux/clk-provider.h b/include/linux/clk-provider.h
> index 1ec14a7..641422c 100644
> --- a/include/linux/clk-provider.h
> +++ b/include/linux/clk-provider.h
> @@ -214,6 +214,9 @@ void of_fixed_clk_setup(struct device_node *np);
>   *   of this register, and mask of gate bits are in higher 16-bit of this
>   *   register.  While setting the gate bits, higher 16-bit should also be
>   *   updated to indicate changing gate bits.
> + * CLK_GATE_ALWAYS_ON - by default this clock could be enable and disable. but
> + *   in some debug condition, must keep this clock on, and never be closed.
> + *   setting this flag then this clock never be closed.

Copy some part from the commit log I just suggested..

If this flag is only for debugging we may name it that way.
Maybe: CLK_GATE_DBG_ALWAYS_ON ??



More information about the linux-arm-kernel mailing list