mbox series

[v2,00/11] Add USB2.0 support.

Message ID 20210621093943.12143-1-biju.das.jz@bp.renesas.com
Headers show
Series Add USB2.0 support. | expand

Message

Biju Das June 21, 2021, 9:39 a.m. UTC
This patch series aims to add USB PHY Control, USB2.0 Host and USB2.0 device
support for RZ/G2L SoC.

v1->v2
 * Updated usb phy control bindings with clock definitions
 * Updated generic ohci/ehci bindings to support RZ/G2L SoC
 * Incorporated vind's review comment on us phy control driver
 * Add support for USB2.0 device and OTG support.

v1:
 - https://patchwork.kernel.org/project/linux-renesas-soc/list/?series=498915

Biju Das (11):
  dt-bindings: phy: renesas: Document RZ/G2L USB PHY Control bindings
  drivers: clk: renesas: r9a07g044-cpg: Add USB clocks
  phy: renesas: Add RZ/G2L usb phy control driver
  arm64: configs: defconfig: Enable RZ/G2L USB PHY control driver
  dt-bindings: phy: renesas,usb2-phy: Document RZ/G2L phy bindings
  dt-bindings: usb: generic-ohci: Document RZ/G2L SoC bindings
  dt-bindings: usb: generic-ehci: Document RZ/G2L SoC bindings
  arm64: dts: renesas: r9a07g044: Add USB2.0 phy and host support
  dt-bindings: usb: renesas,usbhs: Document RZ/G2L bindings
  phy: renesas: phy-rcar-gen3-usb2: Add OTG support for RZ/G2L
  arm64: dts: renesas: r9a07g044: Add USB2.0 device support

 .../phy/renesas,rzg2l-usbphyctrl.yaml         |  65 ++++++++
 .../bindings/phy/renesas,usb2-phy.yaml        |  23 +--
 .../devicetree/bindings/usb/generic-ehci.yaml |  33 +++-
 .../devicetree/bindings/usb/generic-ohci.yaml |  32 +++-
 .../bindings/usb/renesas,usbhs.yaml           |  44 ++++-
 arch/arm64/boot/dts/renesas/r9a07g044.dtsi    | 119 +++++++++++++
 arch/arm64/configs/defconfig                  |   1 +
 drivers/clk/renesas/r9a07g044-cpg.c           |  12 ++
 drivers/phy/renesas/Kconfig                   |   7 +
 drivers/phy/renesas/Makefile                  |   1 +
 drivers/phy/renesas/phy-rcar-gen3-usb2.c      |  63 +++++--
 drivers/phy/renesas/phy-rzg2l-usbphyctrl.c    | 157 ++++++++++++++++++
 12 files changed, 522 insertions(+), 35 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml
 create mode 100644 drivers/phy/renesas/phy-rzg2l-usbphyctrl.c

Comments

Biju Das June 22, 2021, 10:03 a.m. UTC | #1
Hi Rob,

I can reproduce the issue now, after installing 'yamllint' and  using "DT_CHECKER_FLAGS=-m dt_binding_check".

I will fix this and send v3.


Regards,
Biju

> -----Original Message-----

> From: Rob Herring <robh@kernel.org>

> Sent: 21 June 2021 18:40

> To: Biju Das <biju.das.jz@bp.renesas.com>

> Cc: Rob Herring <robh+dt@kernel.org>; Yoshihiro Shimoda

> <yoshihiro.shimoda.uh@renesas.com>; Chris Paterson

> <Chris.Paterson2@renesas.com>; linux-usb@vger.kernel.org; Greg Kroah-

> Hartman <gregkh@linuxfoundation.org>; Geert Uytterhoeven

> <geert+renesas@glider.be>; Biju Das <biju.das@bp.renesas.com>; linux-

> renesas-soc@vger.kernel.org; Prabhakar Mahadev Lad <prabhakar.mahadev-

> lad.rj@bp.renesas.com>; devicetree@vger.kernel.org

> Subject: Re: [PATCH v2 06/11] dt-bindings: usb: generic-ohci: Document

> RZ/G2L SoC bindings

> 

> On Mon, 21 Jun 2021 10:39:38 +0100, Biju Das wrote:

> > Renesas RZ/G2L SoC has USBPHY Control and USB2.0 PHY module. We need

> > to turn on both these phy modules before accessing host registers.

> >

> > Apart from this, document the optional property dr_mode present on

> > both

> > RZ/G2 and R-Car Gen3 SoCs.

> >

> > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>

> > ---

> >  .../devicetree/bindings/usb/generic-ohci.yaml | 32

> > +++++++++++++++++--

> >  1 file changed, 30 insertions(+), 2 deletions(-)

> >

> 

> My bot found errors running 'make DT_CHECKER_FLAGS=-m dt_binding_check'

> on your patch (DT_CHECKER_FLAGS is new in v5.13):

> 

> yamllint warnings/errors:

> ./Documentation/devicetree/bindings/usb/generic-ohci.yaml:14:13: [warning]

> wrong indentation: expected 10 but found 12 (indentation)

> 

> dtschema/dtc warnings/errors:

> \ndoc reference errors (make refcheckdocs):

> 

> See

> https://jpn01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fpatchwor

> k.ozlabs.org%2Fpatch%2F1494981&amp;data=04%7C01%7Cbiju.das.jz%40bp.renesas

> .com%7C948f485a377b4f12c7ea08d934dba3ba%7C53d82571da1947e49cb4625a166a4a2a

> %7C0%7C0%7C637598940229461664%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAi

> LCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&amp;sdata=4rFbOwmthR

> BAmn7MNMAHqQD8hm2lgLSKhUNg9i95A5M%3D&amp;reserved=0

> 

> This check can fail if there are any dependencies. The base for a patch

> series is generally the most recent rc1.

> 

> If you already ran 'make dt_binding_check' and didn't see the above

> error(s), then make sure 'yamllint' is installed and dt-schema is up to

> date:

> 

> pip3 install dtschema --upgrade

> 

> Please check and re-submit.
Rob Herring (Arm) June 22, 2021, 4:58 p.m. UTC | #2
On Mon, Jun 21, 2021 at 10:39:33AM +0100, Biju Das wrote:
> Add device tree binding document for RZ/G2L USB PHY control driver.

> 

> Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>

> ---

> V1->V2:

>  * Add clock properties

> ---

>  .../phy/renesas,rzg2l-usbphyctrl.yaml         | 65 +++++++++++++++++++

>  1 file changed, 65 insertions(+)

>  create mode 100644 Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> 

> diff --git a/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> new file mode 100644

> index 000000000000..8e8ba43f595d

> --- /dev/null

> +++ b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> @@ -0,0 +1,65 @@

> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)

> +%YAML 1.2

> +---

> +$id: http://devicetree.org/schemas/phy/renesas,rzg2l-usbphyctrl.yaml#

> +$schema: http://devicetree.org/meta-schemas/core.yaml#

> +

> +title: Renesas RZ/G2L USB2.0 PHY Control

> +

> +maintainers:

> +  - Biju Das <biju.das.jz@bp.renesas.com>

> +

> +description:

> +  The RZ/G2L USB2.0 PHY Control mainly controls reset and power down of the

> +  USB/PHY.

> +

> +properties:

> +  compatible:

> +    items:

> +      - enum:

> +          - renesas,r9a07g044-usbphyctrl # RZ/G2{L,LC}

> +      - const: renesas,rzg2l-usbphyctrl

> +

> +  reg:

> +    maxItems: 1

> +

> +  clocks:

> +    maxItems: 1

> +

> +  resets:

> +    maxItems: 1

> +

> +  power-domains:

> +    maxItems: 1

> +

> +  '#phy-cells':

> +    # see phy-bindings.txt in the same directory

> +    const: 1

> +    description: |

> +      The phandle's argument in the PHY specifier is the phy reset control bit

> +      of usb phy control.

> +      0 = Port 1 Phy reset

> +      1 = Port 2 Phy reset

> +    enum: [ 0, 1 ]


You already have the const, so this doesn't do anything.

> +

> +required:

> +  - compatible

> +  - reg

> +  - clocks

> +  - '#phy-cells'

> +

> +additionalProperties: false

> +

> +examples:

> +  - |

> +    #include <dt-bindings/clock/r9a07g044-cpg.h>

> +

> +    usbphyctrl@11c40000 {


usb-phy@...

> +        compatible = "renesas,r9a07g044-usbphyctrl",

> +                     "renesas,rzg2l-usbphyctrl";

> +        reg = <0x11c40000 0x10000>;

> +        clocks = <&cpg CPG_MOD R9A07G044_USB_PCLK>;

> +        resets = <&cpg R9A07G044_USB_PCLK>;

> +        power-domains = <&cpg>;

> +        #phy-cells = <1>;

> +    };

> -- 

> 2.17.1

> 

>
Rob Herring (Arm) June 22, 2021, 7:30 p.m. UTC | #3
On Mon, Jun 21, 2021 at 10:39:38AM +0100, Biju Das wrote:
> Renesas RZ/G2L SoC has USBPHY Control and USB2.0 PHY module. We need to

> turn on both these phy modules before accessing host registers.

> 

> Apart from this, document the optional property dr_mode present on both

> RZ/G2 and R-Car Gen3 SoCs.

> 

> Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>

> ---

>  .../devicetree/bindings/usb/generic-ohci.yaml | 32 +++++++++++++++++--

>  1 file changed, 30 insertions(+), 2 deletions(-)

> 

> diff --git a/Documentation/devicetree/bindings/usb/generic-ohci.yaml b/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> index 0f5f6ea702d0..c0644fae5db9 100644

> --- a/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> +++ b/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> @@ -8,6 +8,26 @@ title: USB OHCI Controller Device Tree Bindings

>  

>  allOf:

>    - $ref: "usb-hcd.yaml"

> +  - if:

> +      properties:

> +        compatible:

> +            contains:

> +              const: renesas,r9a07g044-ohci

> +    then:

> +      properties:

> +        phys:

> +          maxItems: 2

> +        phy-names:

> +          items:

> +            - const: usbphyctrl

> +            - const: usb


Why can't your extra thing be last? Then you only need to set 
minItems/maxItems in the if/then schema.

Though this seems like an abuse of the phy binding. There's not 2 phys, 
right? Just some extra registers related to the phy? Can't it be hidden 
in your phy driver?

> +    else:

> +      properties:

> +        phys:

> +          maxItems: 1

> +        phy-names:

> +          items:

> +            - const: usb

>  

>  maintainers:

>    - Greg Kroah-Hartman <gregkh@linuxfoundation.org>

> @@ -43,6 +63,7 @@ properties:

>                - brcm,bcm7435-ohci

>                - ibm,476gtr-ohci

>                - ingenic,jz4740-ohci

> +              - renesas,r9a07g044-ohci

>                - snps,hsdk-v1.0-ohci

>            - const: generic-ohci

>        - const: generic-ohci

> @@ -101,14 +122,21 @@ properties:

>        Overrides the detected port count

>  

>    phys:

> -    maxItems: 1

> +    minItems: 1

> +    maxItems: 2

>  

>    phy-names:

> -    const: usb

> +    minItems: 1

> +    maxItems: 2

>  

>    iommus:

>      maxItems: 1

>  

> +  dr_mode:

> +    enum:

> +      - host

> +      - otg

> +

>  required:

>    - compatible

>    - reg

> -- 

> 2.17.1

> 

>
Biju Das June 23, 2021, 1:38 p.m. UTC | #4
Hi Rob,

Thanks for the feedback.

> Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document RZ/G2L

> USB PHY Control bindings

> 

> On Mon, Jun 21, 2021 at 10:39:33AM +0100, Biju Das wrote:

> > Add device tree binding document for RZ/G2L USB PHY control driver.

> >

> > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>

> > ---

> > V1->V2:

> >  * Add clock properties

> > ---

> >  .../phy/renesas,rzg2l-usbphyctrl.yaml         | 65 +++++++++++++++++++

> >  1 file changed, 65 insertions(+)

> >  create mode 100644

> > Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> >

> > diff --git

> > a/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> > b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> > new file mode 100644

> > index 000000000000..8e8ba43f595d

> > --- /dev/null

> > +++ b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.y

> > +++ aml

> > @@ -0,0 +1,65 @@

> > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML 1.2

> > +---

> > +$id:

> > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fdevi

> > +cetree.org%2Fschemas%2Fphy%2Frenesas%2Crzg2l-usbphyctrl.yaml%23&amp;d

> > +ata=04%7C01%7Cbiju.das.jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a08d9

> > +359f07ad%7C53d82571da1947e49cb4625a166a4a2a%7C0%7C0%7C637599779421910

> > +039%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBT

> > +iI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&amp;sdata=Jcf6Om4DehifCe1KO1rmt5LxTB

> > +6jtGoQLD1MoqWGM%2F0%3D&amp;reserved=0

> > +$schema:

> > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fdevi

> > +cetree.org%2Fmeta-schemas%2Fcore.yaml%23&amp;data=04%7C01%7Cbiju.das.

> > +jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a08d9359f07ad%7C53d82571da19

> > +47e49cb4625a166a4a2a%7C0%7C0%7C637599779421910039%7CUnknown%7CTWFpbGZ

> > +sb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%

> > +3D%7C1000&amp;sdata=LlqPRLf9%2BGrEdSapxCFhwxVKcXTVh9ECr%2FXPN0SIzi4%3

> > +D&amp;reserved=0

> > +

> > +title: Renesas RZ/G2L USB2.0 PHY Control

> > +

> > +maintainers:

> > +  - Biju Das <biju.das.jz@bp.renesas.com>

> > +

> > +description:

> > +  The RZ/G2L USB2.0 PHY Control mainly controls reset and power down

> > +of the

> > +  USB/PHY.

> > +

> > +properties:

> > +  compatible:

> > +    items:

> > +      - enum:

> > +          - renesas,r9a07g044-usbphyctrl # RZ/G2{L,LC}

> > +      - const: renesas,rzg2l-usbphyctrl

> > +

> > +  reg:

> > +    maxItems: 1

> > +

> > +  clocks:

> > +    maxItems: 1

> > +

> > +  resets:

> > +    maxItems: 1

> > +

> > +  power-domains:

> > +    maxItems: 1

> > +

> > +  '#phy-cells':

> > +    # see phy-bindings.txt in the same directory

> > +    const: 1

> > +    description: |

> > +      The phandle's argument in the PHY specifier is the phy reset

> control bit

> > +      of usb phy control.

> > +      0 = Port 1 Phy reset

> > +      1 = Port 2 Phy reset

> > +    enum: [ 0, 1 ]

> 

> You already have the const, so this doesn't do anything.


OK, will take out const.

> 

> > +

> > +required:

> > +  - compatible

> > +  - reg

> > +  - clocks

> > +  - '#phy-cells'

> > +

> > +additionalProperties: false

> > +

> > +examples:

> > +  - |

> > +    #include <dt-bindings/clock/r9a07g044-cpg.h>

> > +

> > +    usbphyctrl@11c40000 {

> 

> usb-phy@...


The IP is called USBPHY control. It mainly controls reset and power down of the USB2.0/PHY.

So not sure usb-phy is right one here ? I prefer usb-phy-ctrl instead. Is it ok? Please let me know.

Cheers,
Biju


> > +        compatible = "renesas,r9a07g044-usbphyctrl",

> > +                     "renesas,rzg2l-usbphyctrl";

> > +        reg = <0x11c40000 0x10000>;

> > +        clocks = <&cpg CPG_MOD R9A07G044_USB_PCLK>;

> > +        resets = <&cpg R9A07G044_USB_PCLK>;

> > +        power-domains = <&cpg>;

> > +        #phy-cells = <1>;

> > +    };

> > --

> > 2.17.1

> >

> >
Rob Herring (Arm) June 23, 2021, 2:13 p.m. UTC | #5
On Wed, Jun 23, 2021 at 7:38 AM Biju Das <biju.das.jz@bp.renesas.com> wrote:
>

> Hi Rob,

>

> Thanks for the feedback.

>

> > Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document RZ/G2L

> > USB PHY Control bindings

> >

> > On Mon, Jun 21, 2021 at 10:39:33AM +0100, Biju Das wrote:

> > > Add device tree binding document for RZ/G2L USB PHY control driver.

> > >

> > > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > > Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>

> > > ---

> > > V1->V2:

> > >  * Add clock properties

> > > ---

> > >  .../phy/renesas,rzg2l-usbphyctrl.yaml         | 65 +++++++++++++++++++

> > >  1 file changed, 65 insertions(+)

> > >  create mode 100644

> > > Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> > >

> > > diff --git

> > > a/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> > > b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yaml

> > > new file mode 100644

> > > index 000000000000..8e8ba43f595d

> > > --- /dev/null

> > > +++ b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.y

> > > +++ aml

> > > @@ -0,0 +1,65 @@

> > > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML 1.2

> > > +---

> > > +$id:

> > > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fdevi

> > > +cetree.org%2Fschemas%2Fphy%2Frenesas%2Crzg2l-usbphyctrl.yaml%23&amp;d

> > > +ata=04%7C01%7Cbiju.das.jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a08d9

> > > +359f07ad%7C53d82571da1947e49cb4625a166a4a2a%7C0%7C0%7C637599779421910

> > > +039%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBT

> > > +iI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&amp;sdata=Jcf6Om4DehifCe1KO1rmt5LxTB

> > > +6jtGoQLD1MoqWGM%2F0%3D&amp;reserved=0

> > > +$schema:

> > > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fdevi

> > > +cetree.org%2Fmeta-schemas%2Fcore.yaml%23&amp;data=04%7C01%7Cbiju.das.

> > > +jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a08d9359f07ad%7C53d82571da19

> > > +47e49cb4625a166a4a2a%7C0%7C0%7C637599779421910039%7CUnknown%7CTWFpbGZ

> > > +sb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%

> > > +3D%7C1000&amp;sdata=LlqPRLf9%2BGrEdSapxCFhwxVKcXTVh9ECr%2FXPN0SIzi4%3

> > > +D&amp;reserved=0

> > > +

> > > +title: Renesas RZ/G2L USB2.0 PHY Control

> > > +

> > > +maintainers:

> > > +  - Biju Das <biju.das.jz@bp.renesas.com>

> > > +

> > > +description:

> > > +  The RZ/G2L USB2.0 PHY Control mainly controls reset and power down

> > > +of the

> > > +  USB/PHY.

> > > +

> > > +properties:

> > > +  compatible:

> > > +    items:

> > > +      - enum:

> > > +          - renesas,r9a07g044-usbphyctrl # RZ/G2{L,LC}

> > > +      - const: renesas,rzg2l-usbphyctrl

> > > +

> > > +  reg:

> > > +    maxItems: 1

> > > +

> > > +  clocks:

> > > +    maxItems: 1

> > > +

> > > +  resets:

> > > +    maxItems: 1

> > > +

> > > +  power-domains:

> > > +    maxItems: 1

> > > +

> > > +  '#phy-cells':

> > > +    # see phy-bindings.txt in the same directory

> > > +    const: 1

> > > +    description: |

> > > +      The phandle's argument in the PHY specifier is the phy reset

> > control bit

> > > +      of usb phy control.

> > > +      0 = Port 1 Phy reset

> > > +      1 = Port 2 Phy reset

> > > +    enum: [ 0, 1 ]

> >

> > You already have the const, so this doesn't do anything.

>

> OK, will take out const.


No, 'const' is correct. This is the value of '#phy-cells', not the
contents (we don't have a way to express schema for that).

> > > +required:

> > > +  - compatible

> > > +  - reg

> > > +  - clocks

> > > +  - '#phy-cells'

> > > +

> > > +additionalProperties: false

> > > +

> > > +examples:

> > > +  - |

> > > +    #include <dt-bindings/clock/r9a07g044-cpg.h>

> > > +

> > > +    usbphyctrl@11c40000 {

> >

> > usb-phy@...

>

> The IP is called USBPHY control. It mainly controls reset and power down of the USB2.0/PHY.


Sounds like it should be using the reset binding...

>

> So not sure usb-phy is right one here ? I prefer usb-phy-ctrl instead. Is it ok? Please let me know.


A node with #phy-cells should use the standard phy node names unless
it has other controls. As I said, this doesn't seem to be a phy, so
using #phy-cells here is what seems wrong.

> > > +        compatible = "renesas,r9a07g044-usbphyctrl",

> > > +                     "renesas,rzg2l-usbphyctrl";

> > > +        reg = <0x11c40000 0x10000>;

> > > +        clocks = <&cpg CPG_MOD R9A07G044_USB_PCLK>;

> > > +        resets = <&cpg R9A07G044_USB_PCLK>;

> > > +        power-domains = <&cpg>;


Also, are these all resources of the usbphyctrl block and not just
resources you happen to want in the driver? For example, the
power-domain should be the power island that this block resides in.

> > > +        #phy-cells = <1>;

> > > +    };

> > > --

> > > 2.17.1

> > >

> > >
Biju Das June 23, 2021, 2:20 p.m. UTC | #6
Hi Rob,

Thanks for the feedback.

> Subject: Re: [PATCH v2 06/11] dt-bindings: usb: generic-ohci: Document

> RZ/G2L SoC bindings

> 

> On Mon, Jun 21, 2021 at 10:39:38AM +0100, Biju Das wrote:

> > Renesas RZ/G2L SoC has USBPHY Control and USB2.0 PHY module. We need

> > to turn on both these phy modules before accessing host registers.

> >

> > Apart from this, document the optional property dr_mode present on

> > both

> > RZ/G2 and R-Car Gen3 SoCs.

> >

> > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>

> > ---

> >  .../devicetree/bindings/usb/generic-ohci.yaml | 32

> > +++++++++++++++++--

> >  1 file changed, 30 insertions(+), 2 deletions(-)

> >

> > diff --git a/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> > b/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> > index 0f5f6ea702d0..c0644fae5db9 100644

> > --- a/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> > +++ b/Documentation/devicetree/bindings/usb/generic-ohci.yaml

> > @@ -8,6 +8,26 @@ title: USB OHCI Controller Device Tree Bindings

> >

> >  allOf:

> >    - $ref: "usb-hcd.yaml"

> > +  - if:

> > +      properties:

> > +        compatible:

> > +            contains:

> > +              const: renesas,r9a07g044-ohci

> > +    then:

> > +      properties:

> > +        phys:

> > +          maxItems: 2

> > +        phy-names:

> > +          items:

> > +            - const: usbphyctrl

> > +            - const: usb

> 

> Why can't your extra thing be last? Then you only need to set

> minItems/maxItems in the if/then schema.


OK. will move this to the last and will take out phy-names.

> 

> Though this seems like an abuse of the phy binding. There's not 2 phys,

> right? Just some extra registers related to the phy? Can't it be hidden in

> your phy driver?


Usbphyctrl is separate IP block which mainly controls reset and power down of the actual USB/PHY.
This block has separate registers. So modelled as separate driver and device handles port reset
Based on port index.

Will remove phy-names "usbphyctrl" and will just use "usb" like example here[1]. Is it ok?

[1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/Documentation/devicetree/bindings/usb/usb-hcd.yaml?h=v5.13-rc7

Regards,
Biju


> 

> > +    else:

> > +      properties:

> > +        phys:

> > +          maxItems: 1

> > +        phy-names:

> > +          items:

> > +            - const: usb

> >

> >  maintainers:

> >    - Greg Kroah-Hartman <gregkh@linuxfoundation.org> @@ -43,6 +63,7 @@

> > properties:

> >                - brcm,bcm7435-ohci

> >                - ibm,476gtr-ohci

> >                - ingenic,jz4740-ohci

> > +              - renesas,r9a07g044-ohci

> >                - snps,hsdk-v1.0-ohci

> >            - const: generic-ohci

> >        - const: generic-ohci

> > @@ -101,14 +122,21 @@ properties:

> >        Overrides the detected port count

> >

> >    phys:

> > -    maxItems: 1

> > +    minItems: 1

> > +    maxItems: 2

> >

> >    phy-names:

> > -    const: usb

> > +    minItems: 1

> > +    maxItems: 2

> >

> >    iommus:

> >      maxItems: 1

> >

> > +  dr_mode:

> > +    enum:

> > +      - host

> > +      - otg

> > +

> >  required:

> >    - compatible

> >    - reg

> > --

> > 2.17.1

> >

> >
Geert Uytterhoeven June 23, 2021, 2:29 p.m. UTC | #7
Hi Rob,

On Wed, Jun 23, 2021 at 4:13 PM Rob Herring <robh@kernel.org> wrote:
> On Wed, Jun 23, 2021 at 7:38 AM Biju Das <biju.das.jz@bp.renesas.com> wrote:

> > > Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document RZ/G2L

> > > USB PHY Control bindings

> > >

> > > On Mon, Jun 21, 2021 at 10:39:33AM +0100, Biju Das wrote:

> > > > Add device tree binding document for RZ/G2L USB PHY control driver.

> > > >

> > > > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > > > Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>


> > > > +        compatible = "renesas,r9a07g044-usbphyctrl",

> > > > +                     "renesas,rzg2l-usbphyctrl";

> > > > +        reg = <0x11c40000 0x10000>;

> > > > +        clocks = <&cpg CPG_MOD R9A07G044_USB_PCLK>;

> > > > +        resets = <&cpg R9A07G044_USB_PCLK>;

> > > > +        power-domains = <&cpg>;

>

> Also, are these all resources of the usbphyctrl block and not just

> resources you happen to want in the driver? For example, the

> power-domain should be the power island that this block resides in.


It's a clock domain, not a power area: the block goes into power-save
mode by stopping the module clock controlled by the CPG.

Gr{oetje,eeting}s,

                        Geert

-- 
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org

In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
                                -- Linus Torvalds
Biju Das June 23, 2021, 3:45 p.m. UTC | #8
Hi Rob,

Thanks for the feedback.

> Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document RZ/G2L

> USB PHY Control bindings

> 

> On Wed, Jun 23, 2021 at 7:38 AM Biju Das <biju.das.jz@bp.renesas.com>

> wrote:

> >

> > Hi Rob,

> >

> > Thanks for the feedback.

> >

> > > Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document

> > > RZ/G2L USB PHY Control bindings

> > >

> > > On Mon, Jun 21, 2021 at 10:39:33AM +0100, Biju Das wrote:

> > > > Add device tree binding document for RZ/G2L USB PHY control driver.

> > > >

> > > > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > > > Reviewed-by: Lad Prabhakar

> > > > <prabhakar.mahadev-lad.rj@bp.renesas.com>

> > > > ---

> > > > V1->V2:

> > > >  * Add clock properties

> > > > ---

> > > >  .../phy/renesas,rzg2l-usbphyctrl.yaml         | 65

> +++++++++++++++++++

> > > >  1 file changed, 65 insertions(+)

> > > >  create mode 100644

> > > > Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.yam

> > > > l

> > > >

> > > > diff --git

> > > > a/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.y

> > > > aml

> > > > b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.y

> > > > aml

> > > > new file mode 100644

> > > > index 000000000000..8e8ba43f595d

> > > > --- /dev/null

> > > > +++ b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyct

> > > > +++ rl.y

> > > > +++ aml

> > > > @@ -0,0 +1,65 @@

> > > > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML

> > > > +1.2

> > > > +---

> > > > +$id:

> > > > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%2F

> > > > +devi

> > > > +cetree.org%2Fschemas%2Fphy%2Frenesas%2Crzg2l-usbphyctrl.yaml%23&a

> > > > +mp;d

> > > > +ata=04%7C01%7Cbiju.das.jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a

> > > > +08d9

> > > > +359f07ad%7C53d82571da1947e49cb4625a166a4a2a%7C0%7C0%7C63759977942

> > > > +1910

> > > > +039%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiL

> > > > +CJBT

> > > > +iI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&amp;sdata=Jcf6Om4DehifCe1KO1rmt5

> > > > +LxTB

> > > > +6jtGoQLD1MoqWGM%2F0%3D&amp;reserved=0

> > > > +$schema:

> > > > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%2F

> > > > +devi

> > > > +cetree.org%2Fmeta-

> schemas%2Fcore.yaml%23&amp;data=04%7C01%7Cbiju.das.

> > > > +jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a08d9359f07ad%7C53d82571

> > > > +da19

> > > > +47e49cb4625a166a4a2a%7C0%7C0%7C637599779421910039%7CUnknown%7CTWF

> > > > +pbGZ

> > > > +sb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6

> > > > +Mn0%

> > > > +3D%7C1000&amp;sdata=LlqPRLf9%2BGrEdSapxCFhwxVKcXTVh9ECr%2FXPN0SIz

> > > > +i4%3

> > > > +D&amp;reserved=0

> > > > +

> > > > +title: Renesas RZ/G2L USB2.0 PHY Control

> > > > +

> > > > +maintainers:

> > > > +  - Biju Das <biju.das.jz@bp.renesas.com>

> > > > +

> > > > +description:

> > > > +  The RZ/G2L USB2.0 PHY Control mainly controls reset and power

> > > > +down of the

> > > > +  USB/PHY.

> > > > +

> > > > +properties:

> > > > +  compatible:

> > > > +    items:

> > > > +      - enum:

> > > > +          - renesas,r9a07g044-usbphyctrl # RZ/G2{L,LC}

> > > > +      - const: renesas,rzg2l-usbphyctrl

> > > > +

> > > > +  reg:

> > > > +    maxItems: 1

> > > > +

> > > > +  clocks:

> > > > +    maxItems: 1

> > > > +

> > > > +  resets:

> > > > +    maxItems: 1

> > > > +

> > > > +  power-domains:

> > > > +    maxItems: 1

> > > > +

> > > > +  '#phy-cells':

> > > > +    # see phy-bindings.txt in the same directory

> > > > +    const: 1

> > > > +    description: |

> > > > +      The phandle's argument in the PHY specifier is the phy

> > > > + reset

> > > control bit

> > > > +      of usb phy control.

> > > > +      0 = Port 1 Phy reset

> > > > +      1 = Port 2 Phy reset

> > > > +    enum: [ 0, 1 ]

> > >

> > > You already have the const, so this doesn't do anything.

> >

> > OK, will take out const.

> 

> No, 'const' is correct. This is the value of '#phy-cells', not the

> contents (we don't have a way to express schema for that).


OK.

> 

> > > > +required:

> > > > +  - compatible

> > > > +  - reg

> > > > +  - clocks

> > > > +  - '#phy-cells'

> > > > +

> > > > +additionalProperties: false

> > > > +

> > > > +examples:

> > > > +  - |

> > > > +    #include <dt-bindings/clock/r9a07g044-cpg.h>

> > > > +

> > > > +    usbphyctrl@11c40000 {

> > >

> > > usb-phy@...

> >

> > The IP is called USBPHY control. It mainly controls reset and power down

> of the USB2.0/PHY.

> 

> Sounds like it should be using the reset binding...


This IP has reset, clock control , connection control , clock status and power down setting registers.
Currenty we are using reset registers for turning ON USB/PHY block.

Since it has extra registers I thought of modelling it as a phy device. But we could model as reset device as well.
But it has extra functionalities apart from reset.

So what do you propose here? Model as a reset device or phy device since it is related to phy?
Please share your opinion on this.

Regards,
Biju

> >

> > So not sure usb-phy is right one here ? I prefer usb-phy-ctrl instead.

> Is it ok? Please let me know.

> 

> A node with #phy-cells should use the standard phy node names unless it

> has other controls. 


Apart from reset, it has other controls like  clock control , connection control , clock status and powerdown setting registers.

Cheers,
Biju

As I said, this doesn't seem to be a phy, so using
> #phy-cells here is what seems wrong.

> 

> > > > +        compatible = "renesas,r9a07g044-usbphyctrl",

> > > > +                     "renesas,rzg2l-usbphyctrl";

> > > > +        reg = <0x11c40000 0x10000>;

> > > > +        clocks = <&cpg CPG_MOD R9A07G044_USB_PCLK>;

> > > > +        resets = <&cpg R9A07G044_USB_PCLK>;

> > > > +        power-domains = <&cpg>;

> 

> Also, are these all resources of the usbphyctrl block and not just

> resources you happen to want in the driver? For example, the power-domain

> should be the power island that this block resides in.

> 

> > > > +        #phy-cells = <1>;

> > > > +    };

> > > > --

> > > > 2.17.1

> > > >

> > > >
Biju Das June 25, 2021, 10:11 a.m. UTC | #9
Hi Rob,

> Subject: RE: [PATCH v2 01/11] dt-bindings: phy: renesas: Document RZ/G2L

> USB PHY Control bindings

> 

> Hi Rob,

> 

> Thanks for the feedback.

> 

> > Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document

> > RZ/G2L USB PHY Control bindings

> >

> > On Wed, Jun 23, 2021 at 7:38 AM Biju Das <biju.das.jz@bp.renesas.com>

> > wrote:

> > >

> > > Hi Rob,

> > >

> > > Thanks for the feedback.

> > >

> > > > Subject: Re: [PATCH v2 01/11] dt-bindings: phy: renesas: Document

> > > > RZ/G2L USB PHY Control bindings

> > > >

> > > > On Mon, Jun 21, 2021 at 10:39:33AM +0100, Biju Das wrote:

> > > > > Add device tree binding document for RZ/G2L USB PHY control

> driver.

> > > > >

> > > > > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>

> > > > > Reviewed-by: Lad Prabhakar

> > > > > <prabhakar.mahadev-lad.rj@bp.renesas.com>

> > > > > ---

> > > > > V1->V2:

> > > > >  * Add clock properties

> > > > > ---

> > > > >  .../phy/renesas,rzg2l-usbphyctrl.yaml         | 65

> > +++++++++++++++++++

> > > > >  1 file changed, 65 insertions(+)  create mode 100644

> > > > > Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl.y

> > > > > am

> > > > > l

> > > > >

> > > > > diff --git

> > > > > a/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl

> > > > > .y

> > > > > aml

> > > > > b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphyctrl

> > > > > .y

> > > > > aml

> > > > > new file mode 100644

> > > > > index 000000000000..8e8ba43f595d

> > > > > --- /dev/null

> > > > > +++ b/Documentation/devicetree/bindings/phy/renesas,rzg2l-usbphy

> > > > > +++ ct

> > > > > +++ rl.y

> > > > > +++ aml

> > > > > @@ -0,0 +1,65 @@

> > > > > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML

> > > > > +1.2

> > > > > +---

> > > > > +$id:

> > > > > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%

> > > > > +2F

> > > > > +devi

> > > > > +cetree.org%2Fschemas%2Fphy%2Frenesas%2Crzg2l-usbphyctrl.yaml%23

> > > > > +&a

> > > > > +mp;d

> > > > > +ata=04%7C01%7Cbiju.das.jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa72

> > > > > +2a

> > > > > +08d9

> > > > > +359f07ad%7C53d82571da1947e49cb4625a166a4a2a%7C0%7C0%7C637599779

> > > > > +42

> > > > > +1910

> > > > > +039%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzI

> > > > > +iL

> > > > > +CJBT

> > > > > +iI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&amp;sdata=Jcf6Om4DehifCe1KO1rm

> > > > > +t5

> > > > > +LxTB

> > > > > +6jtGoQLD1MoqWGM%2F0%3D&amp;reserved=0

> > > > > +$schema:

> > > > > +https://jpn01.safelinks.protection.outlook.com/?url=http%3A%2F%

> > > > > +2F

> > > > > +devi

> > > > > +cetree.org%2Fmeta-

> > schemas%2Fcore.yaml%23&amp;data=04%7C01%7Cbiju.das.

> > > > > +jz%40bp.renesas.com%7Cc6bbf5f6ce334eaa722a08d9359f07ad%7C53d825

> > > > > +71

> > > > > +da19

> > > > > +47e49cb4625a166a4a2a%7C0%7C0%7C637599779421910039%7CUnknown%7CT

> > > > > +WF

> > > > > +pbGZ

> > > > > +sb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVC

> > > > > +I6

> > > > > +Mn0%

> > > > > +3D%7C1000&amp;sdata=LlqPRLf9%2BGrEdSapxCFhwxVKcXTVh9ECr%2FXPN0S

> > > > > +Iz

> > > > > +i4%3

> > > > > +D&amp;reserved=0

> > > > > +

> > > > > +title: Renesas RZ/G2L USB2.0 PHY Control

> > > > > +

> > > > > +maintainers:

> > > > > +  - Biju Das <biju.das.jz@bp.renesas.com>

> > > > > +

> > > > > +description:

> > > > > +  The RZ/G2L USB2.0 PHY Control mainly controls reset and power

> > > > > +down of the

> > > > > +  USB/PHY.

> > > > > +

> > > > > +properties:

> > > > > +  compatible:

> > > > > +    items:

> > > > > +      - enum:

> > > > > +          - renesas,r9a07g044-usbphyctrl # RZ/G2{L,LC}

> > > > > +      - const: renesas,rzg2l-usbphyctrl

> > > > > +

> > > > > +  reg:

> > > > > +    maxItems: 1

> > > > > +

> > > > > +  clocks:

> > > > > +    maxItems: 1

> > > > > +

> > > > > +  resets:

> > > > > +    maxItems: 1

> > > > > +

> > > > > +  power-domains:

> > > > > +    maxItems: 1

> > > > > +

> > > > > +  '#phy-cells':

> > > > > +    # see phy-bindings.txt in the same directory

> > > > > +    const: 1

> > > > > +    description: |

> > > > > +      The phandle's argument in the PHY specifier is the phy

> > > > > + reset

> > > > control bit

> > > > > +      of usb phy control.

> > > > > +      0 = Port 1 Phy reset

> > > > > +      1 = Port 2 Phy reset

> > > > > +    enum: [ 0, 1 ]

> > > >

> > > > You already have the const, so this doesn't do anything.

> > >

> > > OK, will take out const.

> >

> > No, 'const' is correct. This is the value of '#phy-cells', not the

> > contents (we don't have a way to express schema for that).

> 

> OK.

> 

> >

> > > > > +required:

> > > > > +  - compatible

> > > > > +  - reg

> > > > > +  - clocks

> > > > > +  - '#phy-cells'

> > > > > +

> > > > > +additionalProperties: false

> > > > > +

> > > > > +examples:

> > > > > +  - |

> > > > > +    #include <dt-bindings/clock/r9a07g044-cpg.h>

> > > > > +

> > > > > +    usbphyctrl@11c40000 {

> > > >

> > > > usb-phy@...

> > >

> > > The IP is called USBPHY control. It mainly controls reset and power

> > > down

> > of the USB2.0/PHY.

> >

> > Sounds like it should be using the reset binding...


OK, Will model this as a reset binding. Since the IP mainly controls reset and power down
Of the USB2.0/PHY. So it is better to have reset binding.

Regards,
Biju

> This IP has reset, clock control , connection control , clock status and

> power down setting registers.

> Currenty we are using reset registers for turning ON USB/PHY block.

> 

> Since it has extra registers I thought of modelling it as a phy device.

> But we could model as reset device as well.

> But it has extra functionalities apart from reset.

> 

> So what do you propose here? Model as a reset device or phy device since

> it is related to phy?

> Please share your opinion on this.

> 

> Regards,

> Biju

> 

> > >

> > > So not sure usb-phy is right one here ? I prefer usb-phy-ctrl instead.

> > Is it ok? Please let me know.

> >

> > A node with #phy-cells should use the standard phy node names unless

> > it has other controls.

> 

> Apart from reset, it has other controls like  clock control , connection

> control , clock status and powerdown setting registers.

> 

> Cheers,

> Biju

> 

> As I said, this doesn't seem to be a phy, so using

> > #phy-cells here is what seems wrong.

> >

> > > > > +        compatible = "renesas,r9a07g044-usbphyctrl",

> > > > > +                     "renesas,rzg2l-usbphyctrl";

> > > > > +        reg = <0x11c40000 0x10000>;

> > > > > +        clocks = <&cpg CPG_MOD R9A07G044_USB_PCLK>;

> > > > > +        resets = <&cpg R9A07G044_USB_PCLK>;

> > > > > +        power-domains = <&cpg>;

> >

> > Also, are these all resources of the usbphyctrl block and not just

> > resources you happen to want in the driver? For example, the

> > power-domain should be the power island that this block resides in.

> >

> > > > > +        #phy-cells = <1>;

> > > > > +    };

> > > > > --

> > > > > 2.17.1

> > > > >

> > > > >