Representation of external memory-mapped devices in DT (gpmc)
Afzal Mohammed
x0148406 at ti.com
Tue Oct 30 06:50:53 EDT 2012
Hi Daniel,
On Monday 29 October 2012 10:52 PM, Daniel Mack wrote:
> On 29.10.2012 16:09, Rob Herring wrote:
>> You may want a CS0 node with nand as a child node of that.
> Hmm, I don't see what that would buy us. The question is which way is
> feasible for storing both the memory region and the cs number in the
> device tree. The CS number should certainly go to the child node, no?
>
> IOW, would it be a good idea to have something like the following layout?
>
> gpmc: gpmc at 50000000 {
> compatible = "ti,gpmc";
> ti,hwmods = "gpmc";
> reg =<0x50000000 0x2000>;
>
> /* cs-reg stores the setup of the controller's
> memory map */
>
> /* offset size */
> cs-reg =<0x0 0x1000000
> .... .....
> .... .....>;
>
> nand: child at 0 {
> /* timings */
> /* peripheral specifics */
> };
> };
>
> I would actually much prefer that approach.
>
> Afzal, because because that way, we can leave the code as-is for now and
> add the "cs-reg" property once the code is switched to dynamic handling.
> What do you think?
I don't know what to say, don't have a good grasp on DT to give
right suggestion.
It seems offset field may not be necessary. memory for connected
peripherals is not fixed, only CS is fixed (as CS pin is hard-wired).
Physical memory can be anywhere between 0-512MB (with
alignment constraints depending on size, refer GPMC_CONFIG7
register), even though right now memory region for peripheral
seems to be fixed (for boards supported in mainline it will be
what bootloader configures), it is possible to have it in a different
region for those peripherals.
And this memory should be presented to child device as resource,
say for smsc911x ethernet driver.
I see some similarity with PCI - BAR's, where address space
is configured (here a difference would be that size needs to
be known while configuring). Size here would be based on
connected peripheral (but no auto detection)
Regards
Afzal
More information about the linux-arm-kernel
mailing list