Commit 3155f4f4 authored by Alan Stern's avatar Alan Stern Committed by Greg Kroah-Hartman

USB: hub: Revert commit bd0e6c96 ("usb: hub: try old enumeration scheme...

USB: hub: Revert commit bd0e6c96 ("usb: hub: try old enumeration scheme first for high speed devices")

Commit bd0e6c96 ("usb: hub: try old enumeration scheme first for
high speed devices") changed the way the hub driver enumerates
high-speed devices.  Instead of using the "new" enumeration scheme
first and switching to the "old" scheme if that doesn't work, we start
with the "old" scheme.  In theory this is better because the "old"
scheme is slightly faster -- it involves resetting the device only
once instead of twice.

However, for a long time Windows used only the "new" scheme.  Zeng Tao
said that Windows 8 and later use the "old" scheme for high-speed
devices, but apparently there are some devices that don't like it.
William Bader reports that the Ricoh webcam built into his Sony Vaio
laptop not only doesn't enumerate under the "old" scheme, it gets hung
up so badly that it won't then enumerate under the "new" scheme!  Only
a cold reset will fix it.

Therefore we will revert the commit and go back to trying the "new"
scheme first for high-speed devices.
Reported-and-tested-by: default avatarWilliam Bader <williambader@hotmail.com>
Ref: https://bugzilla.kernel.org/show_bug.cgi?id=207219Signed-off-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Fixes: bd0e6c96 ("usb: hub: try old enumeration scheme first for high speed devices")
CC: Zeng Tao <prime.zeng@hisilicon.com>
CC: <stable@vger.kernel.org>

Link: https://lore.kernel.org/r/Pine.LNX.4.44L0.2004221611230.11262-100000@iolanthe.rowland.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 9f952e26
...@@ -5187,8 +5187,7 @@ ...@@ -5187,8 +5187,7 @@
usbcore.old_scheme_first= usbcore.old_scheme_first=
[USB] Start with the old device initialization [USB] Start with the old device initialization
scheme, applies only to low and full-speed devices scheme (default 0 = off).
(default 0 = off).
usbcore.usbfs_memory_mb= usbcore.usbfs_memory_mb=
[USB] Memory limit (in MB) for buffers allocated by [USB] Memory limit (in MB) for buffers allocated by
......
...@@ -2728,13 +2728,11 @@ static bool use_new_scheme(struct usb_device *udev, int retry, ...@@ -2728,13 +2728,11 @@ static bool use_new_scheme(struct usb_device *udev, int retry,
{ {
int old_scheme_first_port = int old_scheme_first_port =
port_dev->quirks & USB_PORT_QUIRK_OLD_SCHEME; port_dev->quirks & USB_PORT_QUIRK_OLD_SCHEME;
int quick_enumeration = (udev->speed == USB_SPEED_HIGH);
if (udev->speed >= USB_SPEED_SUPER) if (udev->speed >= USB_SPEED_SUPER)
return false; return false;
return USE_NEW_SCHEME(retry, old_scheme_first_port || old_scheme_first return USE_NEW_SCHEME(retry, old_scheme_first_port || old_scheme_first);
|| quick_enumeration);
} }
/* Is a USB 3.0 port in the Inactive or Compliance Mode state? /* Is a USB 3.0 port in the Inactive or Compliance Mode state?
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment