blob: 644e978cbd3e3026e245b79b2affe69761d59336 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# USB device configuration
3#
4
David Daney900e0622013-08-09 18:17:48 -07005config USB_OHCI_BIG_ENDIAN_DESC
6 bool
7
8config USB_OHCI_BIG_ENDIAN_MMIO
9 bool
10
11config USB_OHCI_LITTLE_ENDIAN
12 bool
13 default n if STB03xxx || PPC_MPC52xx
14 default y
15
David Daney900e0622013-08-09 18:17:48 -070016config USB_EHCI_BIG_ENDIAN_MMIO
17 bool
18
19config USB_EHCI_BIG_ENDIAN_DESC
20 bool
21
David Daneya8edc422012-03-22 14:01:07 -070022menuconfig USB_SUPPORT
23 bool "USB support"
24 depends on HAS_IOMEM
25 default y
26 ---help---
27 This option adds core support for Universal Serial Bus (USB).
28 You will also need drivers from the following menu to make use of it.
29
David Daney53c6bc22012-03-13 15:58:05 -070030if USB_SUPPORT
31
32config USB_COMMON
33 tristate
David Daney53c6bc22012-03-13 15:58:05 -070034
David Daney53c6bc22012-03-13 15:58:05 -070035config USB_ARCH_HAS_HCD
Arnd Bergmannd9ea21a2013-06-04 19:42:22 +020036 def_bool y
David Daney53c6bc22012-03-13 15:58:05 -070037
Linus Torvalds1da177e2005-04-16 15:20:36 -070038# ARM SA1111 chips have a non-PCI based "OHCI-compatible" USB host interface.
39config USB
40 tristate "Support for Host-side USB"
41 depends on USB_ARCH_HAS_HCD
Arnd Bergmannbadf6d42016-03-23 17:45:08 +010042 select USB_COMMON
Clemens Ladischa853a3d2009-04-24 10:12:18 +020043 select NLS # for UTF-8 strings
Linus Torvalds1da177e2005-04-16 15:20:36 -070044 ---help---
45 Universal Serial Bus (USB) is a specification for a serial bus
46 subsystem which offers higher speeds and more features than the
47 traditional PC serial port. The bus supplies power to peripherals
48 and allows for hot swapping. Up to 127 USB peripherals can be
49 connected to a single USB host in a tree structure.
50
51 The USB host is the root of the tree, the peripherals are the
52 leaves and the inner nodes are special USB devices called hubs.
53 Most PCs now have USB host ports, used to connect peripherals
54 such as scanners, keyboards, mice, modems, cameras, disks,
55 flash memory, network links, and printers to the PC.
56
57 Say Y here if your computer has a host-side USB port and you want
58 to use USB devices. You then need to say Y to at least one of the
59 Host Controller Driver (HCD) options below. Choose a USB 1.1
60 controller, such as "UHCI HCD support" or "OHCI HCD support",
61 and "EHCI HCD (USB 2.0) support" except for older systems that
62 do not have USB 2.0 support. It doesn't normally hurt to select
63 them all if you are not certain.
64
65 If your system has a device-side USB port, used in the peripheral
66 side of the USB protocol, see the "USB Gadget" framework instead.
67
68 After choosing your HCD, then select drivers for the USB peripherals
69 you'll be using. You may want to check out the information provided
70 in <file:Documentation/usb/> and especially the links given in
71 <file:Documentation/usb/usb-help.txt>.
72
73 To compile this driver as a module, choose M here: the
74 module will be called usbcore.
75
Florian Fainelli25e11ec2013-04-09 14:29:25 +020076if USB
Linus Torvalds1da177e2005-04-16 15:20:36 -070077
Florian Fainelli25e11ec2013-04-09 14:29:25 +020078source "drivers/usb/core/Kconfig"
Felipe Balbi72246da2011-08-19 18:10:58 +030079
Simon Arlott3bea3022008-07-21 20:44:50 +010080source "drivers/usb/mon/Kconfig"
81
Greg Kroah-Hartman470cc412008-09-17 16:34:26 +010082source "drivers/usb/wusbcore/Kconfig"
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084source "drivers/usb/host/Kconfig"
85
Kuninori Morimotof1407d52011-04-04 13:44:59 +090086source "drivers/usb/renesas_usbhs/Kconfig"
87
Linus Torvalds1da177e2005-04-16 15:20:36 -070088source "drivers/usb/class/Kconfig"
89
90source "drivers/usb/storage/Kconfig"
91
Linus Torvalds1da177e2005-04-16 15:20:36 -070092source "drivers/usb/image/Kconfig"
93
Valentina Manea96c27372014-08-20 07:31:00 +030094source "drivers/usb/usbip/Kconfig"
95
Florian Fainelli25e11ec2013-04-09 14:29:25 +020096endif
97
Ezequiel Garcia845c0712013-12-22 00:08:33 -030098source "drivers/usb/musb/Kconfig"
99
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200100source "drivers/usb/dwc3/Kconfig"
101
Paul Zimmerman197ba5f2014-01-13 13:50:09 -0800102source "drivers/usb/dwc2/Kconfig"
103
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200104source "drivers/usb/chipidea/Kconfig"
105
Laurent Pinchart7ef077a2015-01-21 00:56:02 +0200106source "drivers/usb/isp1760/Kconfig"
107
Linus Torvalds1da177e2005-04-16 15:20:36 -0700108comment "USB port drivers"
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200109
110if USB
Linus Torvalds1da177e2005-04-16 15:20:36 -0700111
112config USB_USS720
113 tristate "USS720 parport driver"
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200114 depends on PARPORT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115 select PARPORT_NOT_PC
116 ---help---
117 This driver is for USB parallel port adapters that use the Lucent
118 Technologies USS-720 chip. These cables are plugged into your USB
119 port and provide USB compatibility to peripherals designed with
120 parallel port interfaces.
121
122 The chip has two modes: automatic mode and manual mode. In automatic
123 mode, it looks to the computer like a standard USB printer. Only
124 printers may be connected to the USS-720 in this mode. The generic
125 USB printer driver ("USB Printer support", above) may be used in
126 that mode, and you can say N here if you want to use the chip only
127 in this mode.
128
129 Manual mode is not limited to printers, any parallel port
130 device should work. This driver utilizes manual mode.
131 Note however that some operations are three orders of magnitude
132 slower than on a PCI/ISA Parallel Port, so timing critical
133 applications might not work.
134
135 Say Y here if you own an USS-720 USB->Parport cable and intend to
136 connect anything other than a printer to it.
137
138 To compile this driver as a module, choose M here: the
139 module will be called uss720.
140
141source "drivers/usb/serial/Kconfig"
142
143source "drivers/usb/misc/Kconfig"
144
145source "drivers/usb/atm/Kconfig"
146
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200147endif # USB
148
149source "drivers/usb/phy/Kconfig"
150
Linus Torvalds1da177e2005-04-16 15:20:36 -0700151source "drivers/usb/gadget/Kconfig"
152
Michal Sojka0cfbd322014-09-24 22:43:21 +0200153config USB_LED_TRIG
154 bool "USB LED Triggers"
Peter Chencb9c1cf2016-09-14 09:49:30 +0800155 depends on LEDS_CLASS && LEDS_TRIGGERS
156 select USB_COMMON
Michal Sojka0cfbd322014-09-24 22:43:21 +0200157 help
158 This option adds LED triggers for USB host and/or gadget activity.
159
160 Say Y here if you are working on a system with led-class supported
161 LEDs and you want to use them as activity indicators for USB host or
162 gadget.
163
Peter Chenad764c42016-08-16 17:33:25 +0800164config USB_ULPI_BUS
165 tristate "USB ULPI PHY interface support"
Peter Chencb9c1cf2016-09-14 09:49:30 +0800166 select USB_COMMON
Peter Chenad764c42016-08-16 17:33:25 +0800167 help
168 UTMI+ Low Pin Interface (ULPI) is specification for a commonly used
169 USB 2.0 PHY interface. The ULPI specification defines a standard set
170 of registers that can be used to detect the vendor and product which
171 allows ULPI to be handled as a bus. This module is the driver for that
172 bus.
173
174 The ULPI interfaces (the buses) are registered by the drivers for USB
175 controllers which support ULPI register access and have ULPI PHY
176 attached to them. The ULPI PHY drivers themselves are normal PHY
177 drivers.
178
179 ULPI PHYs provide often functions such as ADP sensing/probing (OTG
180 protocol) and USB charger detection.
181
182 To compile this driver as a module, choose M here: the module will
183 be called ulpi.
184
Jan Engelhardt04d06ad2007-05-10 23:04:13 -0700185endif # USB_SUPPORT