OF compatible MTD platform RAM driver ?
David Gibson
david at gibson.dropbear.id.au
Thu Mar 27 20:07:11 EDT 2008
On Thu, Mar 27, 2008 at 03:23:46PM +0300, Sergei Shtylyov wrote:
> Hello.
>
> David Gibson wrote:
>
>>>> Laurent Pinchart wrote:
>
>> [snip]
>
>>>> Heh, we've gone thru "physmap" before -- it was labelled
>>>> Linux-specific name (well, I'd agree with that).
>
>>> physmap stands for physically mapped. That doesn't sound
>>> Linux-specific to me, the fact that the MTD driver has the same name
>>> is a pure coincidence. linmap-rom and linmap-rom sound even more
>>> Linux-specific :-)
>
>> It may not be Linux specific per se, but it's a bad name, because the
>> fact that the device is physically direct mapped isn't a useful
>> distinguishing feature of the device.
>
> Yeah, it's not a propery of a device itself (yet, the device would be
> useless if this information is not supplied in the tree somehow). Yet
> remember the now ungoing discussion about "reg-shift" property for UARTs --
> some people said that the fact that this property may not be a feature of
> device is irrelevant WRT the binding. :-)
>
>> Main memory is also direct physically mapped, after all, but that's not
>> what you want to cover
>> with this description.
>
> Haven't ever seen the description of memory as a device (unless you mean
> the "memory" node which can hardly be considered proper device -- mainly
> because of their usual placement at the top of the tree, and not where a
> RAM device logically should be in the bus hierarchy).
Yes, I mean the memory node. And although it's no very likely,
there's no inherent reason a RAM device couldn't also be at the top of
the tree, on a CPU with the right sort of localbus.
>> In general how a device is wired is described by where it sits in the
>> tree, not by its properties.
>
> Oh, another argument against "reg-shift" in the Xilinx UART quarry...
> :-)
Not really. I was perhaps a bit strong, wiring information in the
properties isn't necessarily wrong, but it does need a close look.
"reg-shift" is a useful compromise.
>> It only seems like a usefully distinguishing name because it's the
>> Linux "physmap_of" driver that uses it. So in this sense it is a
>> Linux specific name after all. In fact, physmap_of is itself very
>> badly named - right now it only handles direct mapped mtds, but that's
>
> Yeah, because that's what is what it has been written for.
>
>> not inherent; it could be trivially extended to also instantiate a
>> non-direct-mapped device (as long as the underlying mtd layer
>> supported it, of course). It bears no relation at all to the
> > "physmap" driver, except historical accident.
>
> This driver resides on the "top", device mapping layer of the MTD
> hierarchy, and I don't see a point of cramming support for all the possible
> mappings into one driver vs doing it as the *separate* specific drivers in
> drivers/mtd/mapps/
Because doing it as separate drivers would mean duplicating most of
physmap_of for absolutely no reason. I'll say it again there is
*nothing* that actually relies on the direct mapping in physmap_of;
the *only* thing it does is take the device tree information and
marshal it into an initialization call for the appropriate mtd chip
drivers.
I really should get around to sending a patch to rename physmap_of to
"of_mtd.c".
> -- as it has been done in the MTD tree before "the great
> OF revolution". This is really strange idea...
The only reason mtd needs heaps of little "map drivers" (which barely
deserve the title of "driver") is because there wasn't a single
generally available source of information about where and how flash
was mapped so a whole pile of platform or sitation specific ways of
getting that information were needed. With a device tree all that can
be replaced with just getting the information from the device tree.
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
More information about the linux-mtd
mailing list