2022-07-08 06:23:23

by Samuel Holland

[permalink] [raw]
Subject: [PATCH] phy: rockchip-inno-usb2: Ignore OTG IRQs in host mode

When the OTG port is fixed to host mode, the driver does not request its
IRQs, nor does it enable those IRQs in hardware. Similarly, the driver
should ignore the OTG port IRQs when handling the shared interrupt.

Otherwise, it would update the extcon based on an ID pin which may be in
an undefined state, or try to queue a uninitialized work item.

Fixes: 6a98df08ccd5 ("phy: rockchip-inno-usb2: Fix muxed interrupt support")
Reported-by: Frank Wunderlich <[email protected]>
Signed-off-by: Samuel Holland <[email protected]>
---

drivers/phy/rockchip/phy-rockchip-inno-usb2.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
index 6711659f727c..26b841c49ec6 100644
--- a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
+++ b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
@@ -978,7 +978,9 @@ static irqreturn_t rockchip_usb2phy_irq(int irq, void *data)

switch (rport->port_id) {
case USB2PHY_PORT_OTG:
- ret |= rockchip_usb2phy_otg_mux_irq(irq, rport);
+ if (rport->mode != USB_DR_MODE_HOST &&
+ rport->mode != USB_DR_MODE_UNKNOWN)
+ ret |= rockchip_usb2phy_otg_mux_irq(irq, rport);
break;
case USB2PHY_PORT_HOST:
ret |= rockchip_usb2phy_linestate_irq(irq, rport);
--
2.35.1


2022-07-08 12:26:36

by Frank Wunderlich

[permalink] [raw]
Subject: Aw: [PATCH] phy: rockchip-inno-usb2: Ignore OTG IRQs in host mode

Hi Samuel

thx for the fix...with this it works again

Tested-by: Frank Wunderlich <[email protected]>

regards Frank


> Gesendet: Freitag, 08. Juli 2022 um 08:14 Uhr
> Von: "Samuel Holland" <[email protected]>
> An: "Frank Wunderlich" <[email protected]>, "Vinod Koul" <[email protected]>
> Cc: "Greg Kroah-Hartman" <[email protected]>, "Peter Geis" <[email protected]>, "Samuel Holland" <[email protected]>, "Heiko Stuebner" <[email protected]>, "Kishon Vijay Abraham I" <[email protected]>, [email protected], [email protected], [email protected], [email protected]
> Betreff: [PATCH] phy: rockchip-inno-usb2: Ignore OTG IRQs in host mode
>
> When the OTG port is fixed to host mode, the driver does not request its
> IRQs, nor does it enable those IRQs in hardware. Similarly, the driver
> should ignore the OTG port IRQs when handling the shared interrupt.
>
> Otherwise, it would update the extcon based on an ID pin which may be in
> an undefined state, or try to queue a uninitialized work item.
>
> Fixes: 6a98df08ccd5 ("phy: rockchip-inno-usb2: Fix muxed interrupt support")
> Reported-by: Frank Wunderlich <[email protected]>
> Signed-off-by: Samuel Holland <[email protected]>
> ---
>
> drivers/phy/rockchip/phy-rockchip-inno-usb2.c | 4 +++-
> 1 file changed, 3 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
> index 6711659f727c..26b841c49ec6 100644
> --- a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
> +++ b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
> @@ -978,7 +978,9 @@ static irqreturn_t rockchip_usb2phy_irq(int irq, void *data)
>
> switch (rport->port_id) {
> case USB2PHY_PORT_OTG:
> - ret |= rockchip_usb2phy_otg_mux_irq(irq, rport);
> + if (rport->mode != USB_DR_MODE_HOST &&
> + rport->mode != USB_DR_MODE_UNKNOWN)
> + ret |= rockchip_usb2phy_otg_mux_irq(irq, rport);
> break;
> case USB2PHY_PORT_HOST:
> ret |= rockchip_usb2phy_linestate_irq(irq, rport);
> --
> 2.35.1
>
>

2022-07-08 13:46:47

by Peter Geis

[permalink] [raw]
Subject: Re: [PATCH] phy: rockchip-inno-usb2: Ignore OTG IRQs in host mode

Good Morning,

I've confirmed this also resolves the issues with phy warnings on quartz64-a.
Tested-by: Peter Geis <[email protected]>

Very Respectfully,
Peter Geis

On Fri, Jul 8, 2022 at 7:47 AM Frank Wunderlich <[email protected]> wrote:
>
> Hi Samuel
>
> thx for the fix...with this it works again
>
> Tested-by: Frank Wunderlich <[email protected]>
>
> regards Frank
>
>
> > Gesendet: Freitag, 08. Juli 2022 um 08:14 Uhr
> > Von: "Samuel Holland" <[email protected]>
> > An: "Frank Wunderlich" <[email protected]>, "Vinod Koul" <[email protected]>
> > Cc: "Greg Kroah-Hartman" <[email protected]>, "Peter Geis" <[email protected]>, "Samuel Holland" <[email protected]>, "Heiko Stuebner" <[email protected]>, "Kishon Vijay Abraham I" <[email protected]>, [email protected], [email protected], [email protected], [email protected]
> > Betreff: [PATCH] phy: rockchip-inno-usb2: Ignore OTG IRQs in host mode
> >
> > When the OTG port is fixed to host mode, the driver does not request its
> > IRQs, nor does it enable those IRQs in hardware. Similarly, the driver
> > should ignore the OTG port IRQs when handling the shared interrupt.
> >
> > Otherwise, it would update the extcon based on an ID pin which may be in
> > an undefined state, or try to queue a uninitialized work item.
> >
> > Fixes: 6a98df08ccd5 ("phy: rockchip-inno-usb2: Fix muxed interrupt support")
> > Reported-by: Frank Wunderlich <[email protected]>
> > Signed-off-by: Samuel Holland <[email protected]>
> > ---
> >
> > drivers/phy/rockchip/phy-rockchip-inno-usb2.c | 4 +++-
> > 1 file changed, 3 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
> > index 6711659f727c..26b841c49ec6 100644
> > --- a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
> > +++ b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
> > @@ -978,7 +978,9 @@ static irqreturn_t rockchip_usb2phy_irq(int irq, void *data)
> >
> > switch (rport->port_id) {
> > case USB2PHY_PORT_OTG:
> > - ret |= rockchip_usb2phy_otg_mux_irq(irq, rport);
> > + if (rport->mode != USB_DR_MODE_HOST &&
> > + rport->mode != USB_DR_MODE_UNKNOWN)
> > + ret |= rockchip_usb2phy_otg_mux_irq(irq, rport);
> > break;
> > case USB2PHY_PORT_HOST:
> > ret |= rockchip_usb2phy_linestate_irq(irq, rport);
> > --
> > 2.35.1
> >
> >

2022-07-15 11:50:34

by Vinod Koul

[permalink] [raw]
Subject: Re: [PATCH] phy: rockchip-inno-usb2: Ignore OTG IRQs in host mode

On 08-07-22, 01:14, Samuel Holland wrote:
> When the OTG port is fixed to host mode, the driver does not request its
> IRQs, nor does it enable those IRQs in hardware. Similarly, the driver
> should ignore the OTG port IRQs when handling the shared interrupt.
>
> Otherwise, it would update the extcon based on an ID pin which may be in
> an undefined state, or try to queue a uninitialized work item.

Applied, thanks

--
~Vinod