Jamie Iles wrote at Saturday, August 13, 2011 4:49 AM:
> On Sat, Aug 13, 2011 at 11:43:23AM +0100, Jamie Iles wrote:
> > Hi Stephen,
> >
> > On Fri, Aug 12, 2011 at 04:54:55PM -0600, Stephen Warren wrote:
...
> > > diff --git a/arch/arm/mach-tegra/pinmux.c b/arch/arm/mach-tegra/pinmux.c
...
> > > +#ifdef CONFIG_OF
> > > +static void __init tegra_pinmux_probe_dt(struct platform_device *pdev)
> > > +{
> > > + int pg;
> > > +
> > > + for (pg = 0; pg < TEGRA_MAX_PINGROUP; pg++) {
> > > +         const char *pg_name = pingroup_name(pg);
> > > +         struct tegra_pingroup_config config;
> > > +         struct device_node *pg_node;
> > > +         int ret;
> > > +         const char *s;
> > > +
> > > +         pg_node = of_find_child_node_by_name(pdev->dev.of_node,
> > > +                                              pg_name);
> > > +         if (pg_node == NULL)
> > > +                 continue;
> >
> > Rather than iterating over all of the mux names in the pinmux driver and
> > searching for a matching DT node, could you not do it the other way
> > round?  So do an for_each_child_of_node() on the pinmux node then find
> > the matching pingroup keyed by the node name?  This would eliminate
> > of_find_child_node_by_name().  You could also catch invalid
> > configurations for non-existent pins this way.
> 
> I just re-read your introduction email and saw you've already discussed
> this!  Would this require an explicit pin name property though or could
> you just key off of the pg_node->name?

No, I think pg_node->name will work out fine; it's what 
of_find_child_node_by_name
is using anyway.

-- 
nvpublic

_______________________________________________
devicetree-discuss mailing list
[email protected]
https://lists.ozlabs.org/listinfo/devicetree-discuss

Reply via email to