forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge tag 'usb-3.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/…
…git/gregkh/usb Pull USB 3.5-rc1 changes from Greg Kroah-Hartman: "Here is the big USB 3.5-rc1 pull request for the 3.5-rc1 merge window. It's touches a lot of different parts of the kernel, all USB drivers, due to some API cleanups (getting rid of the ancient err() macro) and some changes that are needed for USB 3.0 power management updates. There are also lots of new drivers, pimarily gadget, but others as well. We deleted a staging driver, which was nice, and finally dropped the obsolete usbfs code, which will make Al happy to never have to touch that again. There were some build errors in the tree that linux-next found a few days ago, but those were fixed by the most recent changes (all were due to us not building with CONFIG_PM disabled.) Signed-off-by: Greg Kroah-Hartman <[email protected]>" * tag 'usb-3.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: (477 commits) xhci: Fix DIV_ROUND_UP compile error. xhci: Fix compile with CONFIG_USB_SUSPEND=n USB: Fix core compile with CONFIG_USB_SUSPEND=n brcm80211: Fix compile error for .disable_hub_initiated_lpm. Revert "USB: EHCI: work around bug in the Philips ISP1562 controller" MAINTAINERS: Add myself as maintainer to the USB PHY Layer USB: EHCI: fix command register configuration lost problem USB: Remove races in devio.c USB: ehci-platform: remove update_device USB: Disable hub-initiated LPM for comms devices. xhci: Add Intel U1/U2 timeout policy. xhci: Add infrastructure for host-specific LPM policies. USB: Add macros for interrupt endpoint types. xhci: Reserve one command for USB3 LPM disable. xhci: Some Evaluate Context commands must succeed. USB: Disable USB 3.0 LPM in critical sections. USB: Add support to enable/disable USB3 link states. USB: Allow drivers to disable hub-initiated LPM. USB: Calculate USB 3.0 exit latencies for LPM. USB: Refactor code to set LPM support flag. ... Conflicts: arch/arm/mach-exynos/mach-nuri.c arch/arm/mach-exynos/mach-universal_c210.c drivers/net/wireless/ath/ath6kl/usb.c
- Loading branch information
Showing
395 changed files
with
19,447 additions
and
16,215 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -135,6 +135,17 @@ Description: | |
for the device and attempt to bind to it. For example: | ||
# echo "8086 10f5" > /sys/bus/usb/drivers/foo/new_id | ||
|
||
Reading from this file will list all dynamically added | ||
device IDs in the same format, with one entry per | ||
line. For example: | ||
# cat /sys/bus/usb/drivers/foo/new_id | ||
8086 10f5 | ||
dead beef 06 | ||
f00d cafe | ||
|
||
The list will be truncated at PAGE_SIZE bytes due to | ||
sysfs restrictions. | ||
|
||
What: /sys/bus/usb-serial/drivers/.../new_id | ||
Date: October 2011 | ||
Contact: [email protected] | ||
|
@@ -157,6 +168,10 @@ Description: | |
match the driver to the device. For example: | ||
# echo "046d c315" > /sys/bus/usb/drivers/foo/remove_id | ||
|
||
Reading from this file will list the dynamically added | ||
device IDs, exactly like reading from the entry | ||
"/sys/bus/usb/drivers/.../new_id" | ||
|
||
What: /sys/bus/usb/device/.../avoid_reset_quirk | ||
Date: December 2009 | ||
Contact: Oliver Neukum <[email protected]> | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
* NXP ISP1301 USB transceiver | ||
|
||
Required properties: | ||
- compatible: must be "nxp,isp1301" | ||
- reg: I2C address of the ISP1301 device | ||
|
||
Optional properties of devices using ISP1301: | ||
- transceiver: phandle of isp1301 - this helps the ISP1301 driver to find the | ||
ISP1301 instance associated with the respective USB driver | ||
|
||
Example: | ||
|
||
isp1301: usb-transceiver@2c { | ||
compatible = "nxp,isp1301"; | ||
reg = <0x2c>; | ||
}; | ||
|
||
usbd@31020000 { | ||
compatible = "nxp,lpc3220-udc"; | ||
reg = <0x31020000 0x300>; | ||
interrupt-parent = <&mic>; | ||
interrupts = <0x3d 0>, <0x3e 0>, <0x3c 0>, <0x3a 0>; | ||
transceiver = <&isp1301>; | ||
status = "okay"; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
* NXP LPC32xx SoC USB Device Controller (UDC) | ||
|
||
Required properties: | ||
- compatible: Must be "nxp,lpc3220-udc" | ||
- reg: Physical base address of the controller and length of memory mapped | ||
region. | ||
- interrupts: The USB interrupts: | ||
* USB Device Low Priority Interrupt | ||
* USB Device High Priority Interrupt | ||
* USB Device DMA Interrupt | ||
* External USB Transceiver Interrupt (OTG ATX) | ||
- transceiver: phandle of the associated ISP1301 device - this is necessary for | ||
the UDC controller for connecting to the USB physical layer | ||
|
||
Example: | ||
|
||
isp1301: usb-transceiver@2c { | ||
compatible = "nxp,isp1301"; | ||
reg = <0x2c>; | ||
}; | ||
|
||
usbd@31020000 { | ||
compatible = "nxp,lpc3220-udc"; | ||
reg = <0x31020000 0x300>; | ||
interrupt-parent = <&mic>; | ||
interrupts = <0x3d 0>, <0x3e 0>, <0x3c 0>, <0x3a 0>; | ||
transceiver = <&isp1301>; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
* OHCI controller, NXP ohci-nxp variant | ||
|
||
Required properties: | ||
- compatible: must be "nxp,ohci-nxp" | ||
- reg: physical base address of the controller and length of memory mapped | ||
region. | ||
- interrupts: The OHCI interrupt | ||
- transceiver: phandle of the associated ISP1301 device - this is necessary for | ||
the UDC controller for connecting to the USB physical layer | ||
|
||
Example (LPC32xx): | ||
|
||
isp1301: usb-transceiver@2c { | ||
compatible = "nxp,isp1301"; | ||
reg = <0x2c>; | ||
}; | ||
|
||
ohci@31020000 { | ||
compatible = "nxp,ohci-nxp"; | ||
reg = <0x31020000 0x300>; | ||
interrupt-parent = <&mic>; | ||
interrupts = <0x3b 0>; | ||
transceiver = <&isp1301>; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
ST SPEAr SoC USB controllers: | ||
----------------------------- | ||
|
||
EHCI: | ||
----- | ||
|
||
Required properties: | ||
- compatible: "st,spear600-ehci" | ||
- interrupt-parent: Should be the phandle for the interrupt controller | ||
that services interrupts for this device | ||
- interrupts: Should contain the EHCI interrupt | ||
|
||
Example: | ||
|
||
ehci@e1800000 { | ||
compatible = "st,spear600-ehci", "usb-ehci"; | ||
reg = <0xe1800000 0x1000>; | ||
interrupt-parent = <&vic1>; | ||
interrupts = <27>; | ||
}; | ||
|
||
|
||
OHCI: | ||
----- | ||
|
||
Required properties: | ||
- compatible: "st,spear600-ohci" | ||
- interrupt-parent: Should be the phandle for the interrupt controller | ||
that services interrupts for this device | ||
- interrupts: Should contain the OHCI interrupt | ||
|
||
Example: | ||
|
||
ohci@e1900000 { | ||
compatible = "st,spear600-ohci", "usb-ohci"; | ||
reg = <0xe1800000 0x1000>; | ||
interrupt-parent = <&vic1>; | ||
interrupts = <26>; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
*How FunctionFS works* | ||
|
||
From kernel point of view it is just a composite function with some | ||
unique behaviour. It may be added to an USB configuration only after | ||
the user space driver has registered by writing descriptors and | ||
strings (the user space program has to provide the same information | ||
that kernel level composite functions provide when they are added to | ||
the configuration). | ||
|
||
This in particular means that the composite initialisation functions | ||
may not be in init section (ie. may not use the __init tag). | ||
|
||
From user space point of view it is a file system which when | ||
mounted provides an "ep0" file. User space driver need to | ||
write descriptors and strings to that file. It does not need | ||
to worry about endpoints, interfaces or strings numbers but | ||
simply provide descriptors such as if the function was the | ||
only one (endpoints and strings numbers starting from one and | ||
interface numbers starting from zero). The FunctionFS changes | ||
them as needed also handling situation when numbers differ in | ||
different configurations. | ||
|
||
When descriptors and strings are written "ep#" files appear | ||
(one for each declared endpoint) which handle communication on | ||
a single endpoint. Again, FunctionFS takes care of the real | ||
numbers and changing of the configuration (which means that | ||
"ep1" file may be really mapped to (say) endpoint 3 (and when | ||
configuration changes to (say) endpoint 2)). "ep0" is used | ||
for receiving events and handling setup requests. | ||
|
||
When all files are closed the function disables itself. | ||
|
||
What I also want to mention is that the FunctionFS is designed in such | ||
a way that it is possible to mount it several times so in the end | ||
a gadget could use several FunctionFS functions. The idea is that | ||
each FunctionFS instance is identified by the device name used | ||
when mounting. | ||
|
||
One can imagine a gadget that has an Ethernet, MTP and HID interfaces | ||
where the last two are implemented via FunctionFS. On user space | ||
level it would look like this: | ||
|
||
$ insmod g_ffs.ko idVendor=<ID> iSerialNumber=<string> functions=mtp,hid | ||
$ mkdir /dev/ffs-mtp && mount -t functionfs mtp /dev/ffs-mtp | ||
$ ( cd /dev/ffs-mtp && mtp-daemon ) & | ||
$ mkdir /dev/ffs-hid && mount -t functionfs hid /dev/ffs-hid | ||
$ ( cd /dev/ffs-hid && hid-daemon ) & | ||
|
||
On kernel level the gadget checks ffs_data->dev_name to identify | ||
whether it's FunctionFS designed for MTP ("mtp") or HID ("hid"). | ||
|
||
If no "functions" module parameters is supplied, the driver accepts | ||
just one function with any name. | ||
|
||
When "functions" module parameter is supplied, only functions | ||
with listed names are accepted. In particular, if the "functions" | ||
parameter's value is just a one-element list, then the behaviour | ||
is similar to when there is no "functions" at all; however, | ||
only a function with the specified name is accepted. | ||
|
||
The gadget is registered only after all the declared function | ||
filesystems have been mounted and USB descriptors of all functions | ||
have been written to their ep0's. | ||
|
||
Conversely, the gadget is unregistered after the first USB function | ||
closes its endpoints. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1826,6 +1826,12 @@ L: [email protected] (moderated for non-subscribers) | |
S: Maintained | ||
F: Documentation/zh_CN/ | ||
|
||
CHIPIDEA USB HIGH SPEED DUAL ROLE CONTROLLER | ||
M: Alexander Shishkin <[email protected]> | ||
L: [email protected] | ||
S: Maintained | ||
F: drivers/usb/chipidea/ | ||
|
||
CISCO VIC ETHERNET NIC DRIVER | ||
M: Christian Benvenuti <[email protected]> | ||
M: Roopa Prabhu <[email protected]> | ||
|
@@ -7053,6 +7059,14 @@ W: http://pegasus2.sourceforge.net/ | |
S: Maintained | ||
F: drivers/net/usb/pegasus.* | ||
|
||
USB PHY LAYER | ||
M: Felipe Balbi <[email protected]> | ||
L: [email protected] | ||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/balbi/usb.git | ||
S: Maintained | ||
F: drivers/usb/phy/ | ||
F: drivers/usb/otg/ | ||
|
||
USB PRINTER DRIVER (usblp) | ||
M: Pete Zaitcev <[email protected]> | ||
L: [email protected] | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.