Re: [PATCH V4 08/12] boot_constraint: Manage deferrable constraints

From: Russell King - ARM Linux
Date: Wed Dec 13 2017 - 05:33:47 EST


On Wed, Dec 13, 2017 at 03:57:07PM +0530, Viresh Kumar wrote:
> On 13-12-17, 10:53, Greg Kroah-Hartman wrote:
> > On Sun, Oct 29, 2017 at 07:18:56PM +0530, Viresh Kumar wrote:
> > > +static void add_deferrable_of_single(struct device_node *np,
> > > + struct dev_boot_constraint *constraints,
> > > + int count)
> > > +{
> > > + struct device *dev;
> > > + int ret;
> > > +
> > > + if (!of_device_is_available(np))
> > > + return;
> > > +
> > > + ret = of_platform_bus_create(np, NULL, NULL, NULL, false);
> > > + if (ret)
> > > + return;
> > > +
> > > + if (of_device_is_compatible(np, "arm,primecell")) {
> >
> > Why is "arm,primecell" in the core code here?
>
> All we need here is a struct device pointer to add constraints. But how we get
> the device node depends on what bus type the device corresponds to. Currently
> this only support amba and platform devices, but we may need to get spi, i2c,
> etc later on.
>
> How do you suggest to keep this stuff out of core here ? Are you asking me to
> add a generic API in the OF core to find the struct device pointer using a node
> pointer ?

Why do we need this? Why can't we lookup the "struct device" by DT
node, and then look at the device's bus type and decide what to do
from that?

Wouldn't a better solution be to use fwnode stuff for this, and
make the bus-type handling a property of the bus type itself,
pushing the bus specific code into the bus layer?

--
RMK's Patch system: http://www.armlinux.org.uk/developer/patches/
FTTC broadband for 0.8mile line in suburbia: sync at 8.8Mbps down 630kbps up
According to speedtest.net: 8.21Mbps down 510kbps up