RE: [PATCH net] dt-bindings: net: tja11xx: fix the broken binding

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



> -----Original Message-----
> From: Rob Herring <robh@xxxxxxxxxx>
> Sent: 2024年9月4日 22:57
> To: Wei Fang <wei.fang@xxxxxxx>
> Cc: davem@xxxxxxxxxxxxx; pabeni@xxxxxxxxxx; krzk+dt@xxxxxxxxxx;
> conor+dt@xxxxxxxxxx; andrew@xxxxxxx; f.fainelli@xxxxxxxxx;
> hkallweit1@xxxxxxxxx; netdev@xxxxxxxxxxxxxxx; devicetree@xxxxxxxxxxxxxxx;
> linux-kernel@xxxxxxxxxxxxxxx; imx@xxxxxxxxxxxxxxx
> Subject: Re: [PATCH net] dt-bindings: net: tja11xx: fix the broken binding
> 
> On Mon, Sep 02, 2024 at 02:33:52PM +0800, Wei Fang wrote:
> > As Rob pointed in another mail thread [1], the binding of tja11xx PHY
> > is completely broken, the schema cannot catch the error in the DTS. A
> > compatiable string must be needed if we want to add a custom propety.
> > So extract known PHY IDs from the tja11xx PHY drivers and convert them
> > into supported compatible string list to fix the broken binding issue.
> >
> > [1]:
> > https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Flore
> > .kernel.org%2Fnetdev%2F31058f49-bac5-49a9-a422-c43b121bf049%40kernel
> .o
> >
> rg%2FT%2F&data=05%7C02%7Cwei.fang%40nxp.com%7C5616407288034aee9
> cf508dc
> >
> ccf1e1c8%7C686ea1d3bc2b4c6fa92cd99c5c301635%7C0%7C0%7C6386105864
> 643564
> >
> 75%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiL
> CJBTiI
> >
> 6Ik1haWwiLCJXVCI6Mn0%3D%7C0%7C%7C%7C&sdata=TxuYnwBHxDKIdA5qxds
> 8sb4fzyi
> > Tk80cqyM4X0mk5PY%3D&reserved=0
> >
> > Fixes: 52b2fe4535ad ("dt-bindings: net: tja11xx: add nxp,refclk_in
> > property")
> > Signed-off-by: Wei Fang <wei.fang@xxxxxxx>
> > ---
> >  .../devicetree/bindings/net/nxp,tja11xx.yaml  | 50
> > +++++++++++++------
> >  1 file changed, 34 insertions(+), 16 deletions(-)
> >
> > diff --git a/Documentation/devicetree/bindings/net/nxp,tja11xx.yaml
> > b/Documentation/devicetree/bindings/net/nxp,tja11xx.yaml
> > index 85bfa45f5122..c2a1835863e1 100644
> > --- a/Documentation/devicetree/bindings/net/nxp,tja11xx.yaml
> > +++ b/Documentation/devicetree/bindings/net/nxp,tja11xx.yaml
> > @@ -14,8 +14,41 @@ maintainers:
> >  description:
> >    Bindings for NXP TJA11xx automotive PHYs
> >
> > +properties:
> > +  compatible:
> > +    enum:
> > +      - ethernet-phy-id0180.dc40
> > +      - ethernet-phy-id0180.dd00
> > +      - ethernet-phy-id0180.dc80
> > +      - ethernet-phy-id001b.b010
> > +      - ethernet-phy-id001b.b031
> > +
> >  allOf:
> >    - $ref: ethernet-phy.yaml#
> > +  - if:
> > +      properties:
> > +        compatible:
> > +          contains:
> > +            enum:
> > +              - ethernet-phy-id0180.dc40
> > +              - ethernet-phy-id0180.dd00
> > +    then:
> > +      properties:
> > +        nxp,rmii-refclk-in:
> > +          type: boolean
> > +          description: |
> > +            The REF_CLK is provided for both transmitted and received
> data
> > +            in RMII mode. This clock signal is provided by the PHY and is
> > +            typically derived from an external 25MHz crystal.
> Alternatively,
> > +            a 50MHz clock signal generated by an external oscillator can
> be
> > +            connected to pin REF_CLK. A third option is to connect a
> 25MHz
> > +            clock to pin CLK_IN_OUT. So, the REF_CLK should be
> configured
> > +            as input or output according to the actual circuit connection.
> > +            If present, indicates that the REF_CLK will be configured as
> > +            interface reference clock input when RMII mode enabled.
> > +            If not present, the REF_CLK will be configured as interface
> > +            reference clock output when RMII mode enabled.
> > +            Only supported on TJA1100 and TJA1101.
> >
> >  patternProperties:
> >    "^ethernet-phy@[0-9a-f]+$":
> > @@ -32,22 +65,6 @@ patternProperties:
> >          description:
> >            The ID number for the child PHY. Should be +1 of parent PHY.
> >
> > -      nxp,rmii-refclk-in:
> > -        type: boolean
> > -        description: |
> > -          The REF_CLK is provided for both transmitted and received data
> > -          in RMII mode. This clock signal is provided by the PHY and is
> > -          typically derived from an external 25MHz crystal. Alternatively,
> > -          a 50MHz clock signal generated by an external oscillator can be
> > -          connected to pin REF_CLK. A third option is to connect a 25MHz
> > -          clock to pin CLK_IN_OUT. So, the REF_CLK should be configured
> > -          as input or output according to the actual circuit connection.
> > -          If present, indicates that the REF_CLK will be configured as
> > -          interface reference clock input when RMII mode enabled.
> > -          If not present, the REF_CLK will be configured as interface
> > -          reference clock output when RMII mode enabled.
> > -          Only supported on TJA1100 and TJA1101.
> > -
> >      required:
> >        - reg
> >
> > @@ -60,6 +77,7 @@ examples:
> >          #size-cells = <0>;
> >
> >          tja1101_phy0: ethernet-phy@4 {
> > +            compatible = "ethernet-phy-id0180.dc40";
> >              reg = <0x4>;
> >              nxp,rmii-refclk-in;
> 
> Are child phy devices optional? Either way, would be good to show a child device.
> IOW, make examples as complete as possible showing optional
> properties/nodes.
> 
The "nxp,rmii-refclk-in" property is only applicable to TJA1100/TJA1101 PHYs, which
do not have a child phy device.





[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux