linux/drivers/usb
Arnd Bergmann 86f630e5b7 usb: musb/ux500: remove duplicate check for dma_is_compatible
commit 62a6abdd42 upstream.

When dma_addr_t is 64-bit, we get a warning about an invalid cast
in the call to ux500_dma_is_compatible() from ux500_dma_channel_program():

drivers/usb/musb/ux500_dma.c: In function 'ux500_dma_channel_program':
drivers/usb/musb/ux500_dma.c:210:51: error: cast to pointer from integer of different size [-Werror=int-to-pointer-cast]
  if (!ux500_dma_is_compatible(channel, packet_sz, (void *)dma_addr, len))

The problem is that ux500_dma_is_compatible() is called from the
main musb driver on the virtual address, but here we pass in a
DMA address, so the types are fundamentally different but it works
because the function only checks the alignment of the buffer and
that is the same.

We could work around this by adding another cast, but I have checked
that the buffer we get passed here is already checked before it
gets mapped, so the second check seems completely unnecessary
and removing it must be the cleanest solution.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Felipe Balbi <balbi@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-02-25 11:03:45 +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 usb: dwc2: fix regression on big-endian PowerPC/ARM systems 2016-07-27 09:47:28 -07:00
dwc3 usb: dwc3: replace %p with %pK 2017-07-15 11:57:45 +02:00
early
gadget usb: gadget: uvc: Missing files for configfs interface 2018-02-16 20:09:40 +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 usb: isp1760: udc: add ep capabilities support 2015-08-04 12:26:55 -05:00
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: remove duplicate check for dma_is_compatible 2018-02-25 11:03:45 +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: keep usbip_device sockfd state in sync with tcp_socket 2018-02-25 11:03:38 +01:00
wusbcore USB: wusbcore: fix NULL-deref at probe 2017-03-30 09:35:17 +02:00
Kconfig
Makefile usb-host: Remove fusbh200 driver 2015-10-16 23:44:33 -07:00
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.