Re: [PATCH v2 2/5] ARM: dts: vfxxx: Add device tree node for OCOTP

From: maitysanchayan
Date: Mon May 02 2016 - 04:18:48 EST


Hello Arnd,

On 16-05-02 09:31:12, Arnd Bergmann wrote:
> On Monday 02 May 2016 12:35:01 Sanchayan Maity wrote:
> > + ocotp@400a5000 {
> > + compatible = "fsl,vf610-ocotp";
> > + #address-cells = <1>;
> > + #size-cells = <1>;
> > + reg = <0x400a5000 0xCF0>;
> > + clocks = <&clks VF610_CLK_OCOTP>;
> > +
> > + ocotp_cfg0: cfg0@410 {
> > + reg = <0x410 0x4>;
> > + };
> > +
> > + ocotp_cfg1: cfg1@420 {
> > + reg = <0x420 0x4>;
> > + };
> > + };
>
> How do the registers of the child nodes relate to the registers of the
> parent? If there are in the same address space, it might be good to
> add a "ranges" property to describe it.

cfg0 and cfg1 are in the same address space viz. 0x400a5410 and 0x400a5420
respectively. These nodes are primarily for use by the NVMEM consumer API in
the SoC bus driver to retrieve the values from these registers leveraging
the NVMEM vf610 ocotp driver.

Based on the NVMEM bindings here
http://lxr.free-electrons.com/source/Documentation/devicetree/bindings/nvmem/nvmem.txt#L33

Thanks.

Regards,
Sanchayan.

>
> Arnd

> Date: Mon, 02 May 2016 12:02:21 +1000
> From: Gavin Shan <gwshan@xxxxxxxxxxxxxxxxxx>
> To: Rob Herring <robherring2@xxxxxxxxx>
> Cc: "devicetree@xxxxxxxxxxxxxxx" <devicetree@xxxxxxxxxxxxxxx>,
> aik@xxxxxxxxx, Gavin Shan <gwshan@xxxxxxxxxxxxxxxxxx>, Grant Likely
> <grant.likely@xxxxxxxxxx>, "linux-pci@xxxxxxxxxxxxxxx"
> <linux-pci@xxxxxxxxxxxxxxx>, Bjorn Helgaas <bhelgaas@xxxxxxxxxx>,
> linuxppc-dev <linuxppc-dev@xxxxxxxxxxxxxxxx>, dja@xxxxxxxxxx
> Subject: Re: [PATCH v8 40/45] drivers/of: Split unflatten_dt_node()
>
> On Wed, Feb 17, 2016 at 08:30:42AM -0600, Rob Herring wrote:
> >On Tue, Feb 16, 2016 at 9:44 PM, Gavin Shan <gwshan@xxxxxxxxxxxxxxxxxx> wrote:
> >> The function unflatten_dt_node() is called recursively to unflatten
> >> device nodes and properties in the FDT blob. It looks complicated
> >> and hard to be understood.
> >>
> >> This splits the function into 3 functions: populate_properties(),
> >> populate_node() and unflatten_dt_node(). populate_properties(),
> >> which is called by populate_node(), creates properties for the
> >> indicated device node. The later one creates the device nodes
> >> from FDT blob. populate_node() gets the offset in FDT blob for
> >> next device nodes and then calls populate_node(). No logical
> >> changes introduced.
> >>
> >> Signed-off-by: Gavin Shan <gwshan@xxxxxxxxxxxxxxxxxx>
> >> ---
> >> drivers/of/fdt.c | 249 ++++++++++++++++++++++++++++++++-----------------------
> >> 1 file changed, 147 insertions(+), 102 deletions(-)
> >
> >One nit, otherwise:
> >
> >Acked-by: Rob Herring <robh@xxxxxxxxxx>
> >
> >[...]
> >
> >> + /* And we process the "ibm,phandle" property
> >> + * used in pSeries dynamic device tree
> >> + * stuff
> >> + */
> >> + if (!strcmp(pname, "ibm,phandle"))
> >> + np->phandle = be32_to_cpup(val);
> >> +
> >> + pp->name = (char *)pname;
> >> + pp->length = sz;
> >> + pp->value = (__be32 *)val;
> >
> >This cast should not be needed.
> >
>
> It's needed. Otherwise, we will have warning. So I will keep it. I just
> went through this one for next revision and sorry for late response.
>
> drivers/of/fdt.c:225:14: warning: assignment discards âconstâ qualifier from pointer target type
> pp->value = val;
> ^
>
> Thanks,
> Gavin
>
> >> + *pprev = pp;
> >> + pprev = &pp->next;
> >> + }
> >
>
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@xxxxxxxxxxxxxxxx
> https://lists.ozlabs.org/listinfo/linuxppc-dev