[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAMdYzYoB-wFGcmDNYrOMKTb0XSseBd7btLarKBB5+TUB-11KjA@mail.gmail.com>
Date: Thu, 16 Jan 2025 08:32:37 -0500
From: Peter Geis <pgwipeout@...il.com>
To: Krzysztof Kozlowski <krzk@...nel.org>
Cc: Heiko Stuebner <heiko@...ech.de>, zyw@...k-chips.com, kever.yang@...k-chips.com,
frank.wang@...k-chips.com, william.wu@...k-chips.com, wulf@...k-chips.com,
linux-rockchip@...ts.infradead.org, Conor Dooley <conor+dt@...nel.org>,
Kishon Vijay Abraham I <kishon@...nel.org>, Krzysztof Kozlowski <krzk+dt@...nel.org>, Rob Herring <robh@...nel.org>,
Vinod Koul <vkoul@...nel.org>, devicetree@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org, linux-kernel@...r.kernel.org,
linux-phy@...ts.infradead.org
Subject: Re: [RFC PATCH v1 2/6] dt-bindings: phy: rockchip: add rk3328 usb3 phy
On Thu, Jan 16, 2025 at 8:08 AM Krzysztof Kozlowski <krzk@...nel.org> wrote:
>
> On 15/01/2025 02:26, Peter Geis wrote:
> > Add documentation for the usb3 phy as implemented on the rk3328 SoC.
> >
> > Signed-off-by: Peter Geis <pgwipeout@...il.com>
> > ---
> >
> > .../bindings/phy/rockchip,inno-usb3phy.yaml | 166 ++++++++++++++++++
> > 1 file changed, 166 insertions(+)
> > create mode 100644 Documentation/devicetree/bindings/phy/rockchip,inno-usb3phy.yaml
> >
> > diff --git a/Documentation/devicetree/bindings/phy/rockchip,inno-usb3phy.yaml b/Documentation/devicetree/bindings/phy/rockchip,inno-usb3phy.yaml
> > new file mode 100644
> > index 000000000000..cde489ca87ab
> > --- /dev/null
> > +++ b/Documentation/devicetree/bindings/phy/rockchip,inno-usb3phy.yaml
> > @@ -0,0 +1,166 @@
> > +# SPDX-License-Identifier: GPL-2.0-only
>
> Wrong license.
>
> Please run scripts/checkpatch.pl and fix reported warnings. After that,
> run also `scripts/checkpatch.pl --strict` and (probably) fix more
> warnings. Some warnings can be ignored, especially from --strict run,
> but the code here looks like it needs a fix. Feel free to get in touch
> if the warning is not clear.
Checkpatch literally told me to change this. Ran against my original
dev binding:
./scripts/checkpatch.pl --strict
Documentation/devicetree/bindings/phy/rockchip,inno-usb3phy.yaml
CHECK: DT binding documents should be licensed (GPL-2.0-only OR BSD-2-Clause)
#1: FILE: Documentation/devicetree/bindings/phy/rockchip,inno-usb3phy.yaml:1:
+# SPDX-License-Identifier: GPL-2.0
>
> > +%YAML 1.2
> > +---
> > +$id: http://devicetree.org/schemas/phy/rockchip,inno-usb3phy.yaml#
> > +$schema: http://devicetree.org/meta-schemas/core.yaml#
> > +
> > +title: Rockchip USB 3.0 phy with Innosilicon IP block
>
> > +
> > +maintainers:
> > + - Heiko Stuebner <heiko@...ech.de>
> > +
> > +properties:
> > + compatible:
> > + enum:
> > + - rockchip,rk3328-usb3phy
>
> Why is this binding entirely different than existing usb2 phy? Nothing
> in common? This looks like made for driver and both - driver and binding
> - duplicating a lot.
Hmm, I hadn't considered merging it into the usb2 binding as it is a
unique (and uniquely broken) device. I'd like Heiko's thoughts on
this.
>
> > +
> > + reg:
> > + maxItems: 1
> > +
> > + clocks:
> > + minItems: 3
>
> Drop
>
> > + maxItems: 3
> > +
> > + clock-names:
> > + items:
> > + - const: refclk-usb3otg
>
> ref
>
> > + - const: usb3phy-otg
>
> otg
>
> > + - const: usb3phy-pipe
>
> pipe
>
> > +
> > + interrupts:
> > + minItems: 4
>
> You code here randomly. reg has only maxItems, clocks have both and this
> have only minItems. Does not make sense. If you get it wrong, I would
> assume you repeat the same mistake but here it is like randomly chosen
> pieces. And this is making me wonder whether this was not sent too fast.
I admit, I dread writing bindings as even now I'm weak in YAML and it
seems to pick and choose what rules it wants to follow.
>
> Anyway: only maxItems.
>
>
> > +
> > + interrupt-names:
> > + items:
> > + - const: bvalid
> > + - const: id
> > + - const: linestate
> > + - const: rxdet
> > +
> > + resets:
> > + minItems: 6
>
> maxItems instead
>
> > +
> > + reset-names:
> > + items:
> > + - const: usb3phy-u2-por
> > + - const: usb3phy-u3-por
> > + - const: usb3phy-pipe-mac
> > + - const: usb3phy-utmi-mac
> > + - const: usb3phy-utmi-apb
> > + - const: usb3phy-pipe-apb
> > +
> > + "#address-cells":
> > + const: 2
> > +
> > + "#size-cells":
> > + const: 2
> > +
> > + ranges: true
> > +
> > +patternProperties:
> > +
>
> Drop blank line
>
> > + utmi-port@[0-9a-f]+$:
>
> This wasn't tested. Missing quotes, missing starting anchor.
make W=1 dt_binding_check didn't complain about it, using the
dt-schema from pip3 from about a week ago.
>
> > + type: object
>
> Explain what are the children here - description.
Fair, will do.
>
>
> > + additionalProperties: false
> > +
> > + properties:
> > + compatible:
> > + enum:
> > + - rockchip,rk3328-usb3phy-utmi
> > +
> > + reg:
> > + maxItems: 1
> > +
> > + "#phy-cells":
> > + const: 0
>
> Does not look correct. Your parent device is the phy, not child. Why do
> you create children per each type of phy?
Because that's how it's done elsewhere in Rockchip's phys [1]. How
should it be done?
>
> > +
> > + phy-supply:
> > + description:
> > + Phandle to a regulator that provides power to VBUS.
> > + See ./phy-bindings.txt for details.
> > +
> > + required:
> > + - compatible
> > + - reg
> > + - "#phy-cells"
> > +
> > + pipe-port@[0-9a-f]+$:
> > + type: object
> > + additionalProperties: false
> > +
> > + properties:
> > + compatible:
> > + enum:
> > + - rockchip,rk3328-usb3phy-pipe
> > +
> > + reg:
> > + maxItems: 1
> > +
> > + "#phy-cells":
> > + const: 0
> > +
> > + phy-supply:
> > + description:
> > + Phandle to a regulator that provides power to VBUS.
> > + See ./phy-bindings.txt for details.
>
> Drop "see ....".
I was tempted to convert phy-bindings.txt over but as above I dread
writing bindings. Will drop.
>
> > +
> > + required:
> > + - compatible
> > + - reg
> > + - "#phy-cells"
> > +
> > +required:
> > + - compatible
> > + - reg
> > + - clocks
> > + - clock-names
> > + - interrupts
> > + - interrupt-names
> > + - resets
> > + - reset-names
> > +
> > +additionalProperties: false
> > +
> > +examples:
> > + - |
> > + #include <dt-bindings/clock/rk3328-cru.h>
> > + #include <dt-bindings/interrupt-controller/arm-gic.h>
> > + #include <dt-bindings/interrupt-controller/irq.h>
> > + soc {
> > + #address-cells = <2>;
> > + #size-cells = <2>;
> > +
> > + usb3phy: usb3-phy@...60000 {
> > + compatible = "rockchip,rk3328-usb3phy";
> > + reg = <0x0 0xff460000 0x0 0x10000>;
> > + clocks = <&cru SCLK_REF_USB3OTG>, <&cru PCLK_USB3PHY_OTG>, <&cru PCLK_USB3PHY_PIPE>;
>
> That's way over the limit. Wrapping is at 80.
Will correct.
>
> > + clock-names = "refclk-usb3otg", "usb3phy-otg", "usb3phy-pipe";
> > + interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>, <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
> > + <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>, <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>;
> > + interrupt-names = "bvalid", "id", "linestate", "rxdet";
>
>
>
I appreciate all the feedback, I'll incorporate the changes you've recommended.
Very Respectfully,
Peter Geis
>
> Best regards,
> Krzysztof
[1] https://elixir.bootlin.com/linux/v6.13-rc3/source/arch/arm64/boot/dts/rockchip/rk3328.dtsi#L887
Powered by blists - more mailing lists