On Fri, May 06, 2016 at 05:55:01PM -0700, Stephen Boyd wrote: > I've applied this to clk-next but still have a question, see > below. > > On 01/08, Charles Keepax wrote: > > diff --git a/drivers/clk/clk-arizona.c b/drivers/clk/clk-arizona.c > > new file mode 100644 > > index 0000000..eaf2877 > > --- /dev/null > > +++ b/drivers/clk/clk-arizona.c > > + > > +static int arizona_clk_of_get_pdata(struct arizona *arizona) > > +{ > > + const char * const pins[] = { "mclk1", "mclk2" }; > > + struct clk *mclk; > > + int i; > > + > > + if (!of_property_read_bool(arizona->dev->of_node, "clocks")) > > + return 0; > > + > > + for (i = 0; i < ARRAY_SIZE(pins); ++i) { > > + mclk = of_clk_get_by_name(arizona->dev->of_node, pins[i]); > > + if (IS_ERR(mclk)) > > + return PTR_ERR(mclk); > > + > > + if (clk_get_rate(mclk) == CLK32K_RATE) { > > + arizona->pdata.clk32k_src = ARIZONA_32KZ_MCLK1 + i; > > + arizona->pdata.clk32k_parent = __clk_get_name(mclk); > > + } > > + > > + clk_put(mclk); > > Could this be done through assigned parents instead of this rate > checking stuff? Presumably DT could tell us how the clk tree > should be configured. > Apologies, I have been working on a v4 that includes these improvements. It does indeed look much nicer using assigned parents etc. I think it might be best to drop these for now until those are ready to send. The only problem I really have left to sort out before I can send it are some locking issues. It is quite tricky to get interaction between the clocking and SPI frameworks to play nicely. The SPI framework will sometimes punt the actually processing for the transfer to a worker thread which will often perform operations on clocks required for the SPI. Because this is a seperate thread it isn't handled by the re-enterant locking in the clock framework. I had been working around this using async transfers for the SPI, but even then I have since found you can get lockdep warnings because of the potential mutex inversion (SPI mutex and the clock one). Any suggestions on this front would be greatly appreciated? Thanks, Charles -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html