phy: cpcap-usb: Fix flakey host idling and enumerating of devices
authorTony Lindgren <tony@atomide.com>
Sun, 22 Dec 2019 18:00:19 +0000 (10:00 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 14 Jan 2020 19:08:39 +0000 (20:08 +0100)
commit 049226b9fd7442149dcbcf55f15408f5973cceda upstream.

We must let the USB host idle things properly before we switch to debug
UART mode. Otherwise the USB host may never idle after disconnecting
devices, and that causes the next enumeration to be flakey.

Cc: Jacopo Mondi <jacopo@jmondi.org>
Cc: Marcel Partap <mpartap@gmx.net>
Cc: Merlijn Wajer <merlijn@wizzup.org>
Cc: Michael Scott <hashcode0f@gmail.com>
Cc: NeKit <nekit1000@gmail.com>
Cc: Pavel Machek <pavel@ucw.cz>
Cc: Sebastian Reichel <sre@kernel.org>
Acked-by: Pavel Machek <pavel@ucw.cz>
Fixes: 6d6ce40f63af ("phy: cpcap-usb: Add CPCAP PMIC USB support")
Signed-off-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/phy/motorola/phy-cpcap-usb.c

index eeb47fddf64b79756eae0065e052e4c5de71386e..9a38741d3546d7583815e5ec581abec3325f9184 100644 (file)
@@ -283,13 +283,13 @@ static void cpcap_usb_detect(struct work_struct *work)
                return;
        }
 
+       cpcap_usb_try_musb_mailbox(ddata, MUSB_VBUS_OFF);
+
        /* Default to debug UART mode */
        error = cpcap_usb_set_uart_mode(ddata);
        if (error)
                goto out_err;
 
-       cpcap_usb_try_musb_mailbox(ddata, MUSB_VBUS_OFF);
-
        dev_dbg(ddata->dev, "set UART mode\n");
 
        return;