On Wed, Aug 5, 2015 at 9:11 AM, Ran Shalit <ransha...@gmail.com> wrote: > On Wed, Aug 5, 2015 at 6:56 AM, Ran Shalit <ransha...@gmail.com> wrote: >> On Wed, Aug 5, 2015 at 12:25 AM, Scott Wood <scottw...@freescale.com> wrote: >>> On Wed, 2015-08-05 at 00:22 +0300, Ran Shalit wrote: >>>> On Tue, Aug 4, 2015 at 11:31 PM, Scott Wood <scottw...@freescale.com> >>>> wrote: >>>> > On Tue, 2015-08-04 at 23:26 +0300, Ran Shalit wrote: >>>> > > On Tue, Aug 4, 2015 at 9:54 PM, Scott Wood <scottw...@freescale.com> >>>> > > wrote: >>>> > > > On Tue, 2015-08-04 at 18:29 +0300, Ran Shalit wrote: >>>> > > > > Hello, >>>> > > > > >>>> > > > > I would please like to ask if describing flash nor used with GPMC, >>>> > > > > whould be done as described in: >>>> > > > > https://www.kernel.org/doc/Documentation/devicetree/bindings/mtd/gpmc-nor.txt >>>> > > > > It is described in the above link as "TI's GPMC", so I'm not sure >>>> > > > > if >>>> > > > > it is relevent for powerpc too. >>>> > > > >>>> > > > That binding is for TI GPMC. >>>> > > > >>>> > > > Are you saying you have some PPC chip that has a flash controller >>>> > > > called >>>> > > > GPMC? >>>> > > > >>>> > > > -Scott >>>> > > > >>>> > > >>>> > > Hi Scott, >>>> > > >>>> > > Thanks, I've worked with TI's chips, so I now understand that I made >>>> > > here some confusion... >>>> > > It is GPCM , not GPMC, my mistake. >>>> > > We already configured it in u-boot, but on doing read/write from >>>> > > kernel it doesn not work. >>>> > > It seems that for the linux to use the correct driver, we need to >>>> > > define the nor in the device tree. >>>> > > Is there any example how to define nor GPCM in device tree ? Is it >>>> > > possible not to override the existing GPCM configuration ? >>>> > >>>> > Pretty much all of the mpc8xxx/qoriq device trees have GPCM NOR defined. >>>> > See >>>> > Documentation/devicetree/bindings/powerpc/fsl/lbc.txt and examples such >>>> > as >>>> > arch/powerpc/boot/dts/p4080ds.dts (part of the lbc node is in >>>> > arch/powerpc/boot/dts/fsl/p4080si-post.dtsi). >>>> > >>>> > Linux will not change the GPCM configuration. >>>> > >>>> > -Scott >>>> > >>>> >>>> On more thing, if I may. >>>> The localbus is also connected to nvram & cpld. >>>> I've noticed that read/write works well, even though I didn't define >>>> anything in device tree. >>>> Is there any reasom to add these devices into device tree, or can we >>>> use the cpld and nvram without the definition in device tree ? >>> >>> I don't know what you're doing in your kernel to access devices that aren't >>> in the device tree. You should add the devices to the device tree, and have >>> the kernel use it rather than hardcoded info. >>> >>> -Scott >>> >> Hi, >> >> Yes I understand. >> But It is worse noting that I have no localbus entry in the device tree. >> Yes, The nvram, cpld which are both connected to device tree, seems to >> work without any issues. >> >> Thanks, >> Ran > > I apologyze for the bad english, I meant "it worth to note" that there > is no localbus entry at all in the device tree. > So I wander how the nvram and cpld worked... > If I may please ask, what should be the "compatible" for generic > devices such as nvram/cpld ? > I assume that if they worked without any entry, it means that there is > no need for specific driver. > > Regards, > Ran
Hi, After studing the localbus configuration as should be configured in device tree for powerpc, I think I have come with the following configuration, (not yet tested on board): localbus@e0005000 { #address-cells = <2>; #size-cells = <1>; compatible = "fsl,mpc8349-localbus", "simple-bus"; reg = <0xe0005000 0x1000>; interrupts = <77 0x8>; interrupt-parent = <&ipic>; /* NOR and NAND Flashes */ ranges = <0x0 0x0 0xff800000 0x00800000 /* 8MB NOR Flash */ 0x1 0x0 0xF8000000 0x08000000 /* User flash (same nor, in burst mode) 128M */ 0x2 0x0 0xf7e00000 0x00200000>; /*NVRAM/CPLD C2 is selected in CPLD , */ /*nvram 0xf7e00000 1MB */ /*cpld 0xf7f00000 1M (<- different address!)*/ nor@0,0 { #address-cells = <1>; #size-cells = <1>; compatible = "cfi-flash"; reg = <0x0 0x0 0x1000000>; #bank-width = <1>; device-width = <4>; }; }; I have some isssue I'm not sure about, and wanted a second opinion: 1. I have not added entry for NVRAM/CPLD (8 bit width interfaces) , but only specifies it in ranges , I assume it is not required becuase it is probably can be treated as simple ram. Is this assumption correct ? 2. The NVRAM/CPLD is using CS2 , which is configured for 2 MB space. The 2 MB is divided to two 1 MB slices. 1 MB is dedicated for NVRAM (though the NVRAM is only 128 KB) and 1 MB is dedicated for CPLD. The division of CS2 into two regions is done in CPLD. 0xf7e00000 - for NVRAM , 0x00100000 0xf7f00000 - for CPLD , 0x00100000 Is it correct to be configured as one range as done above (0x2 0x0 0xf7e00000 0x00200000) ? Thank you very much, Ran _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev