Alessio Igor Bogani bd09a9f531 USB: ftdi_sio: Replace BKL with a mutex %!s(int64=15) %!d(string=hai) anos
..
atm 08add0c780 USB: atm: Use FIELD_SIZEOF, trivial cleanup. %!s(int64=15) %!d(string=hai) anos
c67x00 c38b94017c USB: c67x00: use resource_size(). %!s(int64=15) %!d(string=hai) anos
class 94015f6e6b USB: BKL removal: cdc-wdm %!s(int64=15) %!d(string=hai) anos
core 0880aef49e USB: usbfs_snoop: add data logging back in %!s(int64=15) %!d(string=hai) anos
early 40b52371be USB: fix section mismatch in early ehci dbgp %!s(int64=15) %!d(string=hai) anos
gadget a79df50bba usb: gadgetfs: Convert semaphore to mutex %!s(int64=15) %!d(string=hai) anos
host 8af6096caf USB: remove obsolete config in kernel source (USB_HCD_DMA) %!s(int64=15) %!d(string=hai) anos
image 5a207b4311 USB: BKL removal: mdc800 %!s(int64=15) %!d(string=hai) anos
misc a8d4211f33 USB: remove the berry_charge driver %!s(int64=15) %!d(string=hai) anos
mon 2bc0d10932 usbmon: add bus number to text API %!s(int64=15) %!d(string=hai) anos
musb 9f445cb299 USB: musb: disable double buffering for older RTL versions %!s(int64=15) %!d(string=hai) anos
otg 8f20960cd7 usb: otg: twl4030: move to request_threaded_irq %!s(int64=15) %!d(string=hai) anos
serial bd09a9f531 USB: ftdi_sio: Replace BKL with a mutex %!s(int64=15) %!d(string=hai) anos
storage 46216e4fbe USB: unusual_devs: Add support for multiple Option 3G sticks %!s(int64=15) %!d(string=hai) anos
wusbcore 6ef4852b13 USB class: make USB device id constant %!s(int64=15) %!d(string=hai) anos
Kconfig ca0e9485af USB: host: SL811: allow the hcd on Blackfin systems %!s(int64=15) %!d(string=hai) anos
Makefile 23d3e7a659 USB: MXC: Add i.MX21 specific USB host controller driver. %!s(int64=15) %!d(string=hai) anos
README 9e3e31046f USB: fix directory references in usb/README %!s(int64=17) %!d(string=hai) anos
usb-skeleton.c b92a97efe0 USB: BKL removal: usb-skeleton %!s(int64=15) %!d(string=hai) anos

README

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 ("khubd").

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.