diff mbox series

[v2] arm64: dts: qcom: qcs404: Fix incorrect USB2 PHYs assignment

Message ID 20220711083038.1518529-1-sumit.garg@linaro.org (mailing list archive)
State Accepted
Commit 58577966a42fc0b660b5e2c7c9e5a2241363ea83
Headers show
Series [v2] arm64: dts: qcom: qcs404: Fix incorrect USB2 PHYs assignment | expand

Commit Message

Sumit Garg July 11, 2022, 8:30 a.m. UTC
Currently the DT for QCS404 SoC has setup for 2 USB2 PHYs with one each
assigned to USB3 controller and USB2 controller. This assignment is
incorrect which only works by luck: as when each USB HCI comes up it
configures the *other* controllers PHY which is enough to make them
happy. If, for any reason, we were to disable one of the controllers then
both would stop working.

This was a difficult inconsistency to be caught which was found while
trying to enable USB support in u-boot. So with all the required drivers
ported to u-boot, I couldn't get the same USB storage device enumerated
in u-boot which was being enumerated fine by the kernel.

The root cause of the problem came out to be that I wasn't enabling USB2
PHY: "usb2_phy_prim" in u-boot. Then I realised that via simply disabling
the same USB2 PHY currently assigned to USB2 host controller in the
kernel disabled enumeration for USB3 host controller as well.

So fix this inconsistency by correctly assigning USB2 PHYs.

Fixes: 9375e7d719b3 ("arm64: dts: qcom: qcs404: Add USB devices and PHYs")
Signed-off-by: Sumit Garg <sumit.garg@linaro.org>
---

Changes in v2:
- Update commit message description.

 arch/arm64/boot/dts/qcom/qcs404.dtsi | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

Comments

Daniel Thompson July 11, 2022, 3:46 p.m. UTC | #1
On Mon, Jul 11, 2022 at 02:00:38PM +0530, Sumit Garg wrote:
> Currently the DT for QCS404 SoC has setup for 2 USB2 PHYs with one each
> assigned to USB3 controller and USB2 controller. This assignment is
> incorrect which only works by luck: as when each USB HCI comes up it
> configures the *other* controllers PHY which is enough to make them
> happy. If, for any reason, we were to disable one of the controllers then
> both would stop working.
>
> This was a difficult inconsistency to be caught which was found while
> trying to enable USB support in u-boot. So with all the required drivers
> ported to u-boot, I couldn't get the same USB storage device enumerated
> in u-boot which was being enumerated fine by the kernel.
>
> The root cause of the problem came out to be that I wasn't enabling USB2
> PHY: "usb2_phy_prim" in u-boot. Then I realised that via simply disabling
> the same USB2 PHY currently assigned to USB2 host controller in the
> kernel disabled enumeration for USB3 host controller as well.
>
> So fix this inconsistency by correctly assigning USB2 PHYs.
>
> Fixes: 9375e7d719b3 ("arm64: dts: qcom: qcs404: Add USB devices and PHYs")
> Signed-off-by: Sumit Garg <sumit.garg@linaro.org>

I've not got one of these board (nor any documentation for them) but the
description and change look OK. Thus FWIW:

Reviewed-by: Daniel Thompson <daniel.thompson@linaro.org>


Daniel.


> ---
>
> Changes in v2:
> - Update commit message description.
>
>  arch/arm64/boot/dts/qcom/qcs404.dtsi | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/arch/arm64/boot/dts/qcom/qcs404.dtsi b/arch/arm64/boot/dts/qcom/qcs404.dtsi
> index 513bf7343b2c..50edc11a5bb5 100644
> --- a/arch/arm64/boot/dts/qcom/qcs404.dtsi
> +++ b/arch/arm64/boot/dts/qcom/qcs404.dtsi
> @@ -557,7 +557,7 @@ usb3_dwc3: usb@7580000 {
>  				compatible = "snps,dwc3";
>  				reg = <0x07580000 0xcd00>;
>  				interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
> -				phys = <&usb2_phy_sec>, <&usb3_phy>;
> +				phys = <&usb2_phy_prim>, <&usb3_phy>;
>  				phy-names = "usb2-phy", "usb3-phy";
>  				snps,has-lpm-erratum;
>  				snps,hird-threshold = /bits/ 8 <0x10>;
> @@ -586,7 +586,7 @@ usb@78c0000 {
>  				compatible = "snps,dwc3";
>  				reg = <0x078c0000 0xcc00>;
>  				interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
> -				phys = <&usb2_phy_prim>;
> +				phys = <&usb2_phy_sec>;
>  				phy-names = "usb2-phy";
>  				snps,has-lpm-erratum;
>  				snps,hird-threshold = /bits/ 8 <0x10>;
> --
> 2.25.1
>
Sumit Garg July 12, 2022, 12:32 p.m. UTC | #2
On Mon, 11 Jul 2022 at 21:16, Daniel Thompson
<daniel.thompson@linaro.org> wrote:
>
> On Mon, Jul 11, 2022 at 02:00:38PM +0530, Sumit Garg wrote:
> > Currently the DT for QCS404 SoC has setup for 2 USB2 PHYs with one each
> > assigned to USB3 controller and USB2 controller. This assignment is
> > incorrect which only works by luck: as when each USB HCI comes up it
> > configures the *other* controllers PHY which is enough to make them
> > happy. If, for any reason, we were to disable one of the controllers then
> > both would stop working.
> >
> > This was a difficult inconsistency to be caught which was found while
> > trying to enable USB support in u-boot. So with all the required drivers
> > ported to u-boot, I couldn't get the same USB storage device enumerated
> > in u-boot which was being enumerated fine by the kernel.
> >
> > The root cause of the problem came out to be that I wasn't enabling USB2
> > PHY: "usb2_phy_prim" in u-boot. Then I realised that via simply disabling
> > the same USB2 PHY currently assigned to USB2 host controller in the
> > kernel disabled enumeration for USB3 host controller as well.
> >
> > So fix this inconsistency by correctly assigning USB2 PHYs.
> >
> > Fixes: 9375e7d719b3 ("arm64: dts: qcom: qcs404: Add USB devices and PHYs")
> > Signed-off-by: Sumit Garg <sumit.garg@linaro.org>
>
> I've not got one of these board (nor any documentation for them) but the
> description and change look OK. Thus FWIW:
>
> Reviewed-by: Daniel Thompson <daniel.thompson@linaro.org>
>

Thanks Daniel for the review.

BTW, I did confirmed that this fix is correct with respect to
documentation (SA2150P LINUX USB TECHNICAL OVERVIEW) as well:

2.1 USB memory addresses
■ USB3.0 core address starts with 0x7580000. USB3.0 is connected to:
 □ SS PHY with start address as 0x78000
 □ HS PHY with start address as 0x7a000.
■ USB2.0 core address starts with 0x78c0000; it is connected only to
HS PHY with the start address as 0x7c000.

-Sumit

>
> Daniel.
>
>
> > ---
> >
> > Changes in v2:
> > - Update commit message description.
> >
> >  arch/arm64/boot/dts/qcom/qcs404.dtsi | 4 ++--
> >  1 file changed, 2 insertions(+), 2 deletions(-)
> >
> > diff --git a/arch/arm64/boot/dts/qcom/qcs404.dtsi b/arch/arm64/boot/dts/qcom/qcs404.dtsi
> > index 513bf7343b2c..50edc11a5bb5 100644
> > --- a/arch/arm64/boot/dts/qcom/qcs404.dtsi
> > +++ b/arch/arm64/boot/dts/qcom/qcs404.dtsi
> > @@ -557,7 +557,7 @@ usb3_dwc3: usb@7580000 {
> >                               compatible = "snps,dwc3";
> >                               reg = <0x07580000 0xcd00>;
> >                               interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
> > -                             phys = <&usb2_phy_sec>, <&usb3_phy>;
> > +                             phys = <&usb2_phy_prim>, <&usb3_phy>;
> >                               phy-names = "usb2-phy", "usb3-phy";
> >                               snps,has-lpm-erratum;
> >                               snps,hird-threshold = /bits/ 8 <0x10>;
> > @@ -586,7 +586,7 @@ usb@78c0000 {
> >                               compatible = "snps,dwc3";
> >                               reg = <0x078c0000 0xcc00>;
> >                               interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
> > -                             phys = <&usb2_phy_prim>;
> > +                             phys = <&usb2_phy_sec>;
> >                               phy-names = "usb2-phy";
> >                               snps,has-lpm-erratum;
> >                               snps,hird-threshold = /bits/ 8 <0x10>;
> > --
> > 2.25.1
> >
Daniel Thompson July 12, 2022, 2:05 p.m. UTC | #3
On Tue, Jul 12, 2022 at 06:02:22PM +0530, Sumit Garg wrote:
> On Mon, 11 Jul 2022 at 21:16, Daniel Thompson
> <daniel.thompson@linaro.org> wrote:
> >
> > On Mon, Jul 11, 2022 at 02:00:38PM +0530, Sumit Garg wrote:
> > > Currently the DT for QCS404 SoC has setup for 2 USB2 PHYs with one each
> > > assigned to USB3 controller and USB2 controller. This assignment is
> > > incorrect which only works by luck: as when each USB HCI comes up it
> > > configures the *other* controllers PHY which is enough to make them
> > > happy. If, for any reason, we were to disable one of the controllers then
> > > both would stop working.
> > >
> > > This was a difficult inconsistency to be caught which was found while
> > > trying to enable USB support in u-boot. So with all the required drivers
> > > ported to u-boot, I couldn't get the same USB storage device enumerated
> > > in u-boot which was being enumerated fine by the kernel.
> > >
> > > The root cause of the problem came out to be that I wasn't enabling USB2
> > > PHY: "usb2_phy_prim" in u-boot. Then I realised that via simply disabling
> > > the same USB2 PHY currently assigned to USB2 host controller in the
> > > kernel disabled enumeration for USB3 host controller as well.
> > >
> > > So fix this inconsistency by correctly assigning USB2 PHYs.
> > >
> > > Fixes: 9375e7d719b3 ("arm64: dts: qcom: qcs404: Add USB devices and PHYs")
> > > Signed-off-by: Sumit Garg <sumit.garg@linaro.org>
> >
> > I've not got one of these board (nor any documentation for them) but the
> > description and change look OK. Thus FWIW:
> >
> > Reviewed-by: Daniel Thompson <daniel.thompson@linaro.org>
> >
>
> Thanks Daniel for the review.

No worries.


> BTW, I did confirmed that this fix is correct with respect to
> documentation (SA2150P LINUX USB TECHNICAL OVERVIEW) as well:
>
> 2.1 USB memory addresses
> ■ USB3.0 core address starts with 0x7580000. USB3.0 is connected to:
>  □ SS PHY with start address as 0x78000
>  □ HS PHY with start address as 0x7a000.
> ■ USB2.0 core address starts with 0x78c0000; it is connected only to
> HS PHY with the start address as 0x7c000.

I didn't mean to imply the patch was in any way deficient (the patch
description showed your experimental method pretty clearly).  I just
wanted to be clear that I hadn't double checked anything outside of the
patch itself!


Daniel.
Sumit Garg July 13, 2022, 5:36 a.m. UTC | #4
On Tue, 12 Jul 2022 at 19:35, Daniel Thompson
<daniel.thompson@linaro.org> wrote:
>
> On Tue, Jul 12, 2022 at 06:02:22PM +0530, Sumit Garg wrote:
> > On Mon, 11 Jul 2022 at 21:16, Daniel Thompson
> > <daniel.thompson@linaro.org> wrote:
> > >
> > > On Mon, Jul 11, 2022 at 02:00:38PM +0530, Sumit Garg wrote:
> > > > Currently the DT for QCS404 SoC has setup for 2 USB2 PHYs with one each
> > > > assigned to USB3 controller and USB2 controller. This assignment is
> > > > incorrect which only works by luck: as when each USB HCI comes up it
> > > > configures the *other* controllers PHY which is enough to make them
> > > > happy. If, for any reason, we were to disable one of the controllers then
> > > > both would stop working.
> > > >
> > > > This was a difficult inconsistency to be caught which was found while
> > > > trying to enable USB support in u-boot. So with all the required drivers
> > > > ported to u-boot, I couldn't get the same USB storage device enumerated
> > > > in u-boot which was being enumerated fine by the kernel.
> > > >
> > > > The root cause of the problem came out to be that I wasn't enabling USB2
> > > > PHY: "usb2_phy_prim" in u-boot. Then I realised that via simply disabling
> > > > the same USB2 PHY currently assigned to USB2 host controller in the
> > > > kernel disabled enumeration for USB3 host controller as well.
> > > >
> > > > So fix this inconsistency by correctly assigning USB2 PHYs.
> > > >
> > > > Fixes: 9375e7d719b3 ("arm64: dts: qcom: qcs404: Add USB devices and PHYs")
> > > > Signed-off-by: Sumit Garg <sumit.garg@linaro.org>
> > >
> > > I've not got one of these board (nor any documentation for them) but the
> > > description and change look OK. Thus FWIW:
> > >
> > > Reviewed-by: Daniel Thompson <daniel.thompson@linaro.org>
> > >
> >
> > Thanks Daniel for the review.
>
> No worries.
>
>
> > BTW, I did confirmed that this fix is correct with respect to
> > documentation (SA2150P LINUX USB TECHNICAL OVERVIEW) as well:
> >
> > 2.1 USB memory addresses
> > ■ USB3.0 core address starts with 0x7580000. USB3.0 is connected to:
> >  □ SS PHY with start address as 0x78000
> >  □ HS PHY with start address as 0x7a000.
> > ■ USB2.0 core address starts with 0x78c0000; it is connected only to
> > HS PHY with the start address as 0x7c000.
>
> I didn't mean to imply the patch was in any way deficient (the patch
> description showed your experimental method pretty clearly).  I just
> wanted to be clear that I hadn't double checked anything outside of the
> patch itself!
>

No worries, I see your point. I just wanted to put out this
information for maintainers which I was able to find yesterday.

-Sumit

>
> Daniel.
Bjorn Andersson July 16, 2022, 3:19 p.m. UTC | #5
On Mon, 11 Jul 2022 14:00:38 +0530, Sumit Garg wrote:
> Currently the DT for QCS404 SoC has setup for 2 USB2 PHYs with one each
> assigned to USB3 controller and USB2 controller. This assignment is
> incorrect which only works by luck: as when each USB HCI comes up it
> configures the *other* controllers PHY which is enough to make them
> happy. If, for any reason, we were to disable one of the controllers then
> both would stop working.
> 
> [...]

Applied, thanks!

[1/1] arm64: dts: qcom: qcs404: Fix incorrect USB2 PHYs assignment
      commit: 58577966a42fc0b660b5e2c7c9e5a2241363ea83

Best regards,
diff mbox series

Patch

diff --git a/arch/arm64/boot/dts/qcom/qcs404.dtsi b/arch/arm64/boot/dts/qcom/qcs404.dtsi
index 513bf7343b2c..50edc11a5bb5 100644
--- a/arch/arm64/boot/dts/qcom/qcs404.dtsi
+++ b/arch/arm64/boot/dts/qcom/qcs404.dtsi
@@ -557,7 +557,7 @@  usb3_dwc3: usb@7580000 {
 				compatible = "snps,dwc3";
 				reg = <0x07580000 0xcd00>;
 				interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
-				phys = <&usb2_phy_sec>, <&usb3_phy>;
+				phys = <&usb2_phy_prim>, <&usb3_phy>;
 				phy-names = "usb2-phy", "usb3-phy";
 				snps,has-lpm-erratum;
 				snps,hird-threshold = /bits/ 8 <0x10>;
@@ -586,7 +586,7 @@  usb@78c0000 {
 				compatible = "snps,dwc3";
 				reg = <0x078c0000 0xcc00>;
 				interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
-				phys = <&usb2_phy_prim>;
+				phys = <&usb2_phy_sec>;
 				phy-names = "usb2-phy";
 				snps,has-lpm-erratum;
 				snps,hird-threshold = /bits/ 8 <0x10>;