Hi,

On 08/09/2016 at 16:51:43 +0200, Alexandre Belloni wrote :
> +static void __init of_sama5d4_sckc_setup(struct device_node *np)
> +{
> +     void __iomem *regbase = of_iomap(np, 0);
> +     struct clk *clk = NULL;
> +     struct clk_sama5d4_slow_osc *osc;
> +     struct clk_init_data init;
> +     const char *xtal_name;
> +     const char *parent_names[2] = { "slow_rc_osc", "slow_osc" };
> +     bool bypass;
> +
> +     if (!regbase)
> +             return;
> +
> +     xtal_name = of_clk_get_parent_name(np, 0);
> +
> +     bypass = of_property_read_bool(np, "atmel,osc-bypass");
> +
> +     osc = kzalloc(sizeof(*osc), GFP_KERNEL);
> +     if (!osc)
> +             return;
> +
> +     init.name = parent_names[1];
> +     init.ops = &sama5d4_slow_osc_ops;
> +     init.parent_names = &xtal_name;
> +     init.num_parents = 1;
> +     init.flags = CLK_IGNORE_UNUSED;
> +
> +     osc->hw.init = &init;
> +     osc->sckcr = regbase;
> +     osc->startup_usec = 1200000;
> +
> +     if (bypass)
> +             writel((readl(regbase) | AT91_SCKC_OSC32BYP), regbase);
> +
> +     clk = clk_register(NULL, &osc->hw);
> +     if (IS_ERR(clk))
> +             kfree(osc);
> +
> +     clk = at91_clk_register_slow_rc_osc(regbase, parent_names[0], 32768,
> +                                         250000000, 75);

That one could be a fixed clock as it is actually impossible to
enable/disable it on sama5d4/2.

I'll send an updated patch series (maybe after getting some feedback).

-- 
Alexandre Belloni, Free Electrons
Embedded Linux and Kernel engineering
http://free-electrons.com

Reply via email to