How to handle named resources with DT?
Arnd Bergmann
arnd at arndb.de
Fri Aug 26 01:05:42 EST 2011
On Thursday 25 August 2011, Russell King - ARM Linux wrote:
>
> On Thu, Aug 25, 2011 at 02:16:14AM +0300, Felipe Balbi wrote:
> > on top of all that, for IPs which are used on many SoCs (such as MUSB)
> > it's quite silly to force all users to provide resources in a certain
> > order. It sounds to me that this will be prone to error in many ways
> > until everything is synced up and on the correct order.
> >
> > Ditching _byname is a very bad idea.
>
> I continue to disagree. The current _byname is an abonimation and hack
> to try to "fix" this problem.
>
> _byname should have been implemented differently - rather than overriding
> the resources name field (which is normally specified to be the device
> or driver name), a new field should have been introduced in struct resource
> to carry the resource sub-name (which is really what it is.)
>
> That would have avoided making /proc/iomem completely illegible with
> multiple devices using this feature.
I agree 100%.
I'm also sure that the danger of breaking something by removing the
_byname resource resolution for each driver that we convert to DT
based probing is very small: We already need to change all static
platform_device definitions along with changing the driver, and
identifying them by index is no more ambiguous than accessing an
individual MMIO register by its index. You can even use an enum
or macro to name the indexes like:
enum {
FOO_RESOURCE_SETUP,
FOO_RESOURCE_POWER,
FOO_RESOURCE_BUFFER,
};
static struct resource foo_res[] = {
[FOO_RESOURCE_SETUP] = {
.start = FOO_SETUP_BASE,
.end = FOO_SETUP_BASE + FOO_SETUP_LEN -1,
.flags = IORESOURCE_MEM,
},
[FOO_RESOURCE_POWER] = {
.start = FOO_POWER_BASE,
.end = FOO_POWER_BASE + FOO_POWER_LEN -1,
.flags = IORESOURCE_MEM,
},
[FOO_RESOURCE_BUFFER] = {
.start = FOO_BUFFER_BASE,
.end = FOO_BUFFER_BASE + FOO_BUFFER_LEN -1,
.flags = IORESOURCE_MEM,
},
};
Arnd
More information about the devicetree-discuss
mailing list