Re: [PATCH v2 2/5] clk: at91: Add sama5d4 sckc support

From: Alexandre Belloni
Date: Fri Sep 09 2016 - 06:52:56 EST


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