[PATCH 18/33] clk: ux500: Add a 2-cell Device Tree parser for obtaining PRCC clocks

Ulf Hansson ulf.hansson at linaro.org
Mon Jun 10 16:54:32 EDT 2013


On 6 June 2013 14:17, Lee Jones <lee.jones at linaro.org> wrote:
> PRCC (peripheral and kernel) clocks are specified using a property tuple
> <&phandle base bit>, where 'base' is the peripheral (1, 2, 3, 5 or 6),
> and bit is read-in value into that peripheral stipulated by the hardware
> specification.
>
> Cc: Mike Turquette <mturquette at linaro.org>
> Cc: Ulf Hansson <ulf.hansson at linaro.org>
> Signed-off-by: Lee Jones <lee.jones at linaro.org>
> ---
>  drivers/clk/ux500/u8500_clk.c |   19 +++++++++++++++++++
>  1 file changed, 19 insertions(+)
>
> diff --git a/drivers/clk/ux500/u8500_clk.c b/drivers/clk/ux500/u8500_clk.c
> index ef948ff..3a7040b 100644
> --- a/drivers/clk/ux500/u8500_clk.c
> +++ b/drivers/clk/ux500/u8500_clk.c
> @@ -15,6 +15,25 @@
>  #include <linux/platform_data/clk-ux500.h>
>  #include "clk.h"
>
> +struct clk *ux500_twocell_get(struct of_phandle_args *clkspec, void *data)
> +{
> +       struct clk **clk_data = data;
> +       unsigned int base, bit;
> +
> +       if (clkspec->args_count != 2)
> +               return  ERR_PTR(-EINVAL);
> +
> +       base = clkspec->args[0];
> +       bit = clkspec->args[1];
> +
> +       if (base != 1 && base != 2 && base != 3 && base != 5 && base != 6) {
> +               pr_err("%s: invalid PRCC base %d\n", __func__, base);
> +               return ERR_PTR(-EINVAL);
> +       }
> +
> +       return PRCC_SHOW(clk_data, base, bit);

Where did this macro come from?

Kind regards
Ulf Hansson

> +}
> +
>  const static struct of_device_id u8500_clk_of_match[] = {
>         { .compatible = "stericsson,u8500-clks", },
>         { },
> --
> 1.7.10.4
>



More information about the linux-arm-kernel mailing list