android_kernel_oneplus_msm8998/drivers/usb
Oliver Neukum 1bbdf7649f usb: uas: unconditionally bring back host after reset
commit cbeef22fd611c4f47c494b821b2b105b8af970bb upstream.

Quoting Hans:

If we return 1 from our post_reset handler, then our disconnect handler
will be called immediately afterwards. Since pre_reset blocks all scsi
requests our disconnect handler will then hang in the scsi_remove_host
call.

This is esp. bad because our disconnect handler hanging for ever also
stops the USB subsys from enumerating any new USB devices, causes commands
like lsusb to hang, etc.

In practice this happens when unplugging some uas devices because the hub
code may see the device as needing a warm-reset and calls usb_reset_device
before seeing the disconnect. In this case uas_configure_endpoints fails
with -ENODEV. We do not want to print an error for this, so this commit
also silences the shost_printk for -ENODEV.

ENDQUOTE

However, if we do that we better drop any unconditional execution
and report to the SCSI subsystem that we have undergone a reset
but we are not operational now.

Signed-off-by: Oliver Neukum <oneukum@suse.com>
Reported-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-02-03 17:04:30 +01:00
..
atm
c67x00
chipidea usb: chipidea: vbus event may exist before starting gadget 2017-10-08 10:14:18 +02:00
class CDC-ACM: apply quirk for card reader 2018-02-03 17:04:30 +01:00
common usb: define USB_SPEED_SUPER_PLUS speed for SuperSpeedPlus USB3.1 devices 2016-09-07 08:32:39 +02:00
core USB: Fix off by one in type-specific length check of BOS SSP capability 2018-01-02 20:33:27 +01:00
dwc2
dwc3 usb: dwc3: replace %p with %pK 2017-07-15 11:57:45 +02:00
early
gadget usb: f_fs: Prevent gadget unbind if it is already unbound 2018-02-03 17:04:30 +01:00
host xhci: Fix ring leak in failure path of xhci_alloc_virt_device() 2018-01-17 09:35:29 +01:00
image
isp1760
misc usb: misc: usb3503: make sure reset is low for at least 100us 2018-01-17 09:35:31 +01:00
mon USB: fix usbmon BUG trigger 2018-01-17 09:35:31 +01:00
musb usb: musb: ux500: Fix NULL pointer dereference at system PM 2018-01-17 09:35:28 +01:00
phy usb: phy: isp1301: Add OF device ID table 2017-12-20 10:04:52 +01:00
renesas_usbhs usb: renesas_usbhs: Fix DMAC sequence for receiving zero-length packet 2017-10-18 09:20:41 +02:00
serial USB: serial: simple: add Motorola Tetra driver 2018-02-03 17:04:30 +01:00
storage usb: uas: unconditionally bring back host after reset 2018-02-03 17:04:30 +01:00
usbip usbip: prevent leaking socket pointer address in messages 2018-01-31 12:06:12 +01:00
wusbcore USB: wusbcore: fix NULL-deref at probe 2017-03-30 09:35:17 +02:00
Kconfig
Makefile
README
usb-skeleton.c

To understand all the Linux-USB framework, you'll use these resources:

    * This source code.  This is necessarily an evolving work, and
      includes kerneldoc that should help you get a current overview.
      ("make pdfdocs", and then look at "usb.pdf" for host side and
      "gadget.pdf" for peripheral side.)  Also, Documentation/usb has
      more information.

    * The USB 2.0 specification (from www.usb.org), with supplements
      such as those for USB OTG and the various device classes.
      The USB specification has a good overview chapter, and USB
      peripherals conform to the widely known "Chapter 9".

    * Chip specifications for USB controllers.  Examples include
      host controllers (on PCs, servers, and more); peripheral
      controllers (in devices with Linux firmware, like printers or
      cell phones); and hard-wired peripherals like Ethernet adapters.

    * Specifications for other protocols implemented by USB peripheral
      functions.  Some are vendor-specific; others are vendor-neutral
      but just standardized outside of the www.usb.org team.

Here is a list of what each subdirectory here is, and what is contained in
them.

core/		- This is for the core USB host code, including the
		  usbfs files and the hub class driver ("hub_wq").

host/		- This is for USB host controller drivers.  This
		  includes UHCI, OHCI, EHCI, and others that might
		  be used with more specialized "embedded" systems.

gadget/		- This is for USB peripheral controller drivers and
		  the various gadget drivers which talk to them.


Individual USB driver directories.  A new driver should be added to the
first subdirectory in the list below that it fits into.

image/		- This is for still image drivers, like scanners or
		  digital cameras.
../input/	- This is for any driver that uses the input subsystem,
		  like keyboard, mice, touchscreens, tablets, etc.
../media/	- This is for multimedia drivers, like video cameras,
		  radios, and any other drivers that talk to the v4l
		  subsystem.
../net/		- This is for network drivers.
serial/		- This is for USB to serial drivers.
storage/	- This is for USB mass-storage drivers.
class/		- This is for all USB device drivers that do not fit
		  into any of the above categories, and work for a range
		  of USB Class specified devices. 
misc/		- This is for all USB device drivers that do not fit
		  into any of the above categories.