Hi,
On 12/02/2014 04:45 PM, Maxime Ripard wrote:
>> Ok, so thinking more about this, I'm still convinced that the MFD
framework is only getting in the way here.
You still haven't said of what exactly it's getting in the way of.
Of using of_clk_define to bind to the mod0 clk in the prcm, because the
ir_clk node does not have its own reg property when the mfd framework is
used and of_clk_define requires the node to have its own reg property.
But I can see having things represented in devicetree properly, with
the clocks, etc. as child nodes of the prcm being something which we
want.
Clocks and reset are the only thing set so far, because we need
reference to them from the DT itself, nothing more.
We could very much have more devices instatiated from the MFD itself.
So since all we are using the MFD for is to instantiate platform
devices under the prcm nodes, and assign an io resource for the regs
to them, why not simply make the prcm node itself a simple-bus.
No, this is really not a bus. It shouldn't be described at all as
such. It is a device, that has multiple functionnalities in the system
=> MFD. It really is that simple.
Ok, I can live with that, but likewise the clocks node is not a bus either!
So it should not have a simple-bus compatible either, and as such we cannot
simply change the mod0 driver from of_clk_define to a platform driver because
then we need to instantiate platform devs for the mod0 clock nodes, which
means making the clock node a simple-bus.
I can see your logic in wanting the ir_clk prcm sub-node to use the
mod0 compatible string, so how about we make the mod0 driver both
register through of_declare and as a platform driver. Note this means
that it will try to bind twice to the ir_clk node, since of_clk_declare
will cause it to try and bind there too AFAIK.
The of_clk_declare bind will fail though because there is no regs
property, so this double bind is not an issue as long as we do not
log errors on the first bind failure.
Note that the ir_clk node will still need an "ir-clk" compatible as
well for the MFD to find it and assign the proper resources to it.
But this way we will have the clk driver binding to the mod0 clk compatible,
which is what you want, while having the MFD assign resources on the
fact that it is the ir-clk node, so that things will still work if
there are multiple mod0 clks in the prcm.
This does everything the MFD prcm driver currently does, without
actually needing a specific kernel driver, and as added bonus this
will move the definition of the mfd function reg offsets out of the
kernel and into the devicetree where they belong in the first place.
Which was nacked in the first place because such offsets are not
supposed to be in the DT.
Really, we have something that work here, there's no need to refactor
it.
Ok, but that does bring us back to the original problem wrt the ir-clk,
see above for how I think we should solve this then. If you agree I
can implement the proposed fix.
Regards,
Hans
--
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