[PATCH 2/6] PowerPC 440EPx: Sequoia DTS
Sergei Shtylyov
sshtylyov at ru.mvista.com
Sun Aug 19 22:59:45 EST 2007
Hello.
I'm having sort of vacation, mostly away from computer, hence my belated
reply...
David Gibson wrote:
>>>>>Can you describe some of the options for *not* direct mapped flash
>>>>>chips - I can't reasonably come up with a way of describing the
>>>>>distinction when I've never seen NOR flash other than direct mapped.
>>>> You're lucky to live in the single-endian world. Once you're in bi-endian
>>>>one, all kinds of strange mappings become possible. I've seen the MIPS
>> Well, not necessarily -- 16-bit only accesses are always possibly (no
>>dount this would be a strange mapping however)...
> I have no idea what you're getting at here.
The code fragment that I've posted before -- it used readw() in read8()
method of the mapping.
>>>>mapping driver which required swapping flash bytes in s/w in BE mode, i.e.
>>>>couldn't be served by physmap, yet that's not all... here's the code of its
>>>>map read*() methods:
>>>Aha! Ok, now I understand the sorts of situations you're talking
>>>about. By "not direct mapped", I thought you were talking about some
>>>kind of access via address/data registers on some indirect bus
>>>controller, rather than weird variations on endianness and
>>>bit-swizzling.
>> No, that would be just too ridiculous for a NOR flash -- I hope. :-)
> Heh. In my experience, very little is so ridiculous that some
> embedded vendor won't do it.
Right. :-)
>>>Hrm.. this is a property of how the flash is wired onto the bus,
>>>rather than of the flash chips themselves,
>> Indeed.
>>>so I'm not entirely sure where description of it belongs.
>> So, you're saying that the 1:1 address correspondence rule stops to apply
>>here?
> Well.. it all depends what exactly you consider the address space of
> the flash bank. By which I mean the whole shmozzle represented by the
> device node, not the individual flash chips. It's not immediately
> obvious whether or not that should include any swizzling done by the
> bus wiring.
> It would be possible, I guess, to define a 'swizzled-ranges' property
> or something which allows child devices to be embedded in the parent's
> address range in a not-direct way. However, the swizzling on the
> flash bank is really a property of the flash bank, not of the parent
> bus - requiring it to be encoded in the parent is pretty yucky -
> especially if the flash bank is just part of a larger chunk of bus
> address space, defined by a single large ranges entry in the parent.
[...]
>>>>>>>+ - reg : Address range of the flash chip
>>>>>>>+ - bank-width : Width (in bytes) of the flash bank. Equal to the device width
>>>>>>>+ times the number of interleaved chips.
>>>>>>>+ - device-width : (optional) Width of a single flash chip. If omitted,
>>>>>>>+ assumed to be equal to 'bank-width'.
>>>>>> Why then not just introduce the "interleave" prop and obsolete the
>>>>>>"bank-width"?
>>>>>Because they're equivalent information, and bank-width is what the
>>>>>code ends up actually caring about. I don't see any reason to prefer
>>>>>giving the interleave.
>>>> Well, "device-width" is not the thing that we care about either. ;-)
>>>Well, yes but we need to encode it somehow. Segher preferred
>>>device-width to interleave, because it's closer to a description of
>>>the actual hardware, rather than an abstration decribing its wiring.
>>>In other words I *still* don't see any reason to prefer giving the
>>>interleave.
Well, for example, enable "Flash chip driver advanced configuration
options" (appers in the "RAM/ROM/Flash chip drivers menu" when you enable CFI
probe, and it has a choice of bus widths 8 to 256 bits (here buswidth == bank
width) and *interleave factors* 1 to 8...
>> I wasn't talking of "interleave" preference over "device-width", I was
>>talking about obsoleting "bank-width" with this pair.
> Whatever. You haven't given any argument to prefer interleave over
> either device-width or bank-width.
Consistency? The bank width is a product of the chip width and interleave
factor. However, I don't insist. The MTD core itself has a different view on
the CFI flash geometry: bank width (which is a property of a mapping driver)
and interleave (which is a property of a chip driver).
>>>>>>>Index: working-2.6/drivers/mtd/maps/physmap_of.c
>>>>>>>===================================================================
>>>>>>>--- working-2.6.orig/drivers/mtd/maps/physmap_of.c 2007-07-30 17:07:11.000000000 +1000
>>>>>>>+++ working-2.6/drivers/mtd/maps/physmap_of.c 2007-07-30 17:07:14.000000000 +1000
>>>>[...]
>>>>>>>@@ -221,6 +297,14 @@ err_out:
>>>>>>>
>>>>>>>static struct of_device_id of_physmap_match[] = {
>>>>>>> {
>>>>>>>+ .compatible = "cfi-flash",
>>>>>>>+ .data = (void *)"cfi_probe",
>>>>>>>+ },
>>>>>>>+ {
>>>>>>>+ .compatible = "jedec-flash",
>>>>>>>+ .data = (void *)"jedec_probe",
>>>>>>>+ },
>>>>>>>+ {
>>>>>> This would also trigger on non-linearly mapped CFI or JEDEC
>>>>>>flashes which is not a good idea -- however, as we're using the MTD
>>>>>>probing code anyway, it will just fail, so it's not luckily is not a
>>>>>>fatal design flaw.
>>>>>Well, if there's nothing else to distinguish them. Which there isn't
>>>>>yet, but will need to be: see above about incomplete - helpful
>>>>>suggestions about how to describe the mapping would be more useful
>>>>>than merely pointing out the lack.
>>>> I was thinking about adding "direct-mapped" prop... but maybe adding
>>>>"ranges" to the parent node (that's "ebc") would indeed ensure that the flash
>>>>is mapped 1:1 to the EBC's parent bus also.
>>>The ebc already has a ranges property. But that can't describe the
>> Not in the device tree that started that thread -- I haven't seen another.
> Ah sorry. The ranges property isn't in the dts, it's added by the
> bootwrapper based on the EBC register contents.
Cool. :-)
>>>sorts of bit-swizzling you're talking about.
>> Let's hear what Segher says (if he's not yet tired of all this :-).
>>>>>>>Index: working-2.6/arch/powerpc/boot/dts/ebony.dts
>>>>>>>===================================================================
>>>>>>>--- working-2.6.orig/arch/powerpc/boot/dts/ebony.dts 2007-07-30 17:07:14.000000000 +1000
>>>>>>>+++ working-2.6/arch/powerpc/boot/dts/ebony.dts 2007-07-30 17:07:14.000000000 +1000
>>>>>>[...]
>>>>>>>@@ -158,14 +161,20 @@
>>>>>>> };
>>>>>>> large-flash at 2,0 {
>>>>>> Hmm... what does @2,0 mean? :-O
>>>>>EBC chip select 2, offset 0.
>>>> Well, so this node is under some kind of local bus node -- that's good.
>>>>Didn't know that the spec allows commas after @...
>>>Well, now you do. I believe USB usually uses that format, too.
>> USB what, hosts or devices?
> Devices.
And what the comma-separated numbers mean there?
[...]
WBR, Sergei
More information about the Linuxppc-dev
mailing list