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

Frank Wunderlich frank-w at public-files.de
Fri Jul 8 04:47:14 PDT 2022


Hi Samuel

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

Tested-by: Frank Wunderlich <frank-w at public-files.de>

regards Frank


> Gesendet: Freitag, 08. Juli 2022 um 08:14 Uhr
> Von: "Samuel Holland" <samuel at sholland.org>
> An: "Frank Wunderlich" <frank-w at public-files.de>, "Vinod Koul" <vkoul at kernel.org>
> Cc: "Greg Kroah-Hartman" <gregkh at linuxfoundation.org>, "Peter Geis" <pgwipeout at gmail.com>, "Samuel Holland" <samuel at sholland.org>, "Heiko Stuebner" <heiko at sntech.de>, "Kishon Vijay Abraham I" <kishon at ti.com>, linux-arm-kernel at lists.infradead.org, linux-kernel at vger.kernel.org, linux-phy at lists.infradead.org, linux-rockchip at lists.infradead.org
> 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 <frank-w at public-files.de>
> Signed-off-by: Samuel Holland <samuel at sholland.org>
> ---
>
>  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
>
>



More information about the Linux-rockchip mailing list