blob: e4b27413f528e73a9f7f5ce1862b99b1cf04d455 [file] [log] [blame]
Greg Kroah-Hartmancae8dc32019-01-17 09:23:50 +01001# SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#
3# USB device configuration
4#
5
David Daney900e0622013-08-09 18:17:48 -07006config USB_OHCI_BIG_ENDIAN_DESC
7 bool
8
9config USB_OHCI_BIG_ENDIAN_MMIO
10 bool
11
12config USB_OHCI_LITTLE_ENDIAN
13 bool
14 default n if STB03xxx || PPC_MPC52xx
15 default y
16
David Daney900e0622013-08-09 18:17:48 -070017config USB_EHCI_BIG_ENDIAN_MMIO
18 bool
19
20config USB_EHCI_BIG_ENDIAN_DESC
21 bool
22
James Hoganec897562018-01-31 22:24:45 +000023config USB_UHCI_BIG_ENDIAN_MMIO
24 bool
James Hoganec897562018-01-31 22:24:45 +000025
26config USB_UHCI_BIG_ENDIAN_DESC
27 bool
James Hoganec897562018-01-31 22:24:45 +000028
David Daneya8edc422012-03-22 14:01:07 -070029menuconfig USB_SUPPORT
30 bool "USB support"
31 depends on HAS_IOMEM
32 default y
33 ---help---
34 This option adds core support for Universal Serial Bus (USB).
35 You will also need drivers from the following menu to make use of it.
36
David Daney53c6bc22012-03-13 15:58:05 -070037if USB_SUPPORT
38
39config USB_COMMON
40 tristate
David Daney53c6bc22012-03-13 15:58:05 -070041
David Daney53c6bc22012-03-13 15:58:05 -070042config USB_ARCH_HAS_HCD
Arnd Bergmannd9ea21a2013-06-04 19:42:22 +020043 def_bool y
David Daney53c6bc22012-03-13 15:58:05 -070044
Linus Torvalds1da177e2005-04-16 15:20:36 -070045config USB
46 tristate "Support for Host-side USB"
47 depends on USB_ARCH_HAS_HCD
Arnd Bergmannbadf6d42016-03-23 17:45:08 +010048 select USB_COMMON
Clemens Ladischa853a3d2009-04-24 10:12:18 +020049 select NLS # for UTF-8 strings
Linus Torvalds1da177e2005-04-16 15:20:36 -070050 ---help---
51 Universal Serial Bus (USB) is a specification for a serial bus
52 subsystem which offers higher speeds and more features than the
53 traditional PC serial port. The bus supplies power to peripherals
54 and allows for hot swapping. Up to 127 USB peripherals can be
55 connected to a single USB host in a tree structure.
56
57 The USB host is the root of the tree, the peripherals are the
58 leaves and the inner nodes are special USB devices called hubs.
59 Most PCs now have USB host ports, used to connect peripherals
60 such as scanners, keyboards, mice, modems, cameras, disks,
61 flash memory, network links, and printers to the PC.
62
63 Say Y here if your computer has a host-side USB port and you want
64 to use USB devices. You then need to say Y to at least one of the
65 Host Controller Driver (HCD) options below. Choose a USB 1.1
66 controller, such as "UHCI HCD support" or "OHCI HCD support",
67 and "EHCI HCD (USB 2.0) support" except for older systems that
68 do not have USB 2.0 support. It doesn't normally hurt to select
69 them all if you are not certain.
70
71 If your system has a device-side USB port, used in the peripheral
72 side of the USB protocol, see the "USB Gadget" framework instead.
73
74 After choosing your HCD, then select drivers for the USB peripherals
75 you'll be using. You may want to check out the information provided
76 in <file:Documentation/usb/> and especially the links given in
77 <file:Documentation/usb/usb-help.txt>.
78
79 To compile this driver as a module, choose M here: the
80 module will be called usbcore.
81
yuan linyu2c93e792017-02-25 19:20:55 +080082config USB_PCI
83 bool "PCI based USB host interface"
84 depends on PCI
85 default y
86 ---help---
Chris Mayo2bb80de2017-10-17 17:54:52 +010087 Many embedded system SOCs (e.g. freescale T2080) have both
88 PCI and USB modules with the USB module directly controlled by
89 registers and having no relationship to the PCI module.
yuan linyu2c93e792017-02-25 19:20:55 +080090
Chris Mayo2bb80de2017-10-17 17:54:52 +010091 If you have such a device you may say N here and PCI related code
92 will not be built in the USB driver.
yuan linyu2c93e792017-02-25 19:20:55 +080093
Florian Fainelli25e11ec2013-04-09 14:29:25 +020094if USB
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
Florian Fainelli25e11ec2013-04-09 14:29:25 +020096source "drivers/usb/core/Kconfig"
Felipe Balbi72246da2011-08-19 18:10:58 +030097
Simon Arlott3bea3022008-07-21 20:44:50 +010098source "drivers/usb/mon/Kconfig"
99
Greg Kroah-Hartman470cc412008-09-17 16:34:26 +0100100source "drivers/usb/wusbcore/Kconfig"
101
Linus Torvalds1da177e2005-04-16 15:20:36 -0700102source "drivers/usb/host/Kconfig"
103
Kuninori Morimotof1407d52011-04-04 13:44:59 +0900104source "drivers/usb/renesas_usbhs/Kconfig"
105
Linus Torvalds1da177e2005-04-16 15:20:36 -0700106source "drivers/usb/class/Kconfig"
107
108source "drivers/usb/storage/Kconfig"
109
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110source "drivers/usb/image/Kconfig"
111
Valentina Manea96c27372014-08-20 07:31:00 +0300112source "drivers/usb/usbip/Kconfig"
113
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200114endif
115
Chunfeng Yundf2069a2016-10-19 10:28:23 +0800116source "drivers/usb/mtu3/Kconfig"
117
Ezequiel Garcia845c0712013-12-22 00:08:33 -0300118source "drivers/usb/musb/Kconfig"
119
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200120source "drivers/usb/dwc3/Kconfig"
121
Paul Zimmerman197ba5f2014-01-13 13:50:09 -0800122source "drivers/usb/dwc2/Kconfig"
123
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200124source "drivers/usb/chipidea/Kconfig"
125
Laurent Pinchart7ef077a2015-01-21 00:56:02 +0200126source "drivers/usb/isp1760/Kconfig"
127
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128comment "USB port drivers"
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200129
130if USB
Linus Torvalds1da177e2005-04-16 15:20:36 -0700131
132config USB_USS720
133 tristate "USS720 parport driver"
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200134 depends on PARPORT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700135 select PARPORT_NOT_PC
136 ---help---
137 This driver is for USB parallel port adapters that use the Lucent
138 Technologies USS-720 chip. These cables are plugged into your USB
139 port and provide USB compatibility to peripherals designed with
140 parallel port interfaces.
141
142 The chip has two modes: automatic mode and manual mode. In automatic
143 mode, it looks to the computer like a standard USB printer. Only
144 printers may be connected to the USS-720 in this mode. The generic
145 USB printer driver ("USB Printer support", above) may be used in
146 that mode, and you can say N here if you want to use the chip only
147 in this mode.
148
149 Manual mode is not limited to printers, any parallel port
150 device should work. This driver utilizes manual mode.
151 Note however that some operations are three orders of magnitude
152 slower than on a PCI/ISA Parallel Port, so timing critical
153 applications might not work.
154
155 Say Y here if you own an USS-720 USB->Parport cable and intend to
156 connect anything other than a printer to it.
157
158 To compile this driver as a module, choose M here: the
159 module will be called uss720.
160
161source "drivers/usb/serial/Kconfig"
162
163source "drivers/usb/misc/Kconfig"
164
165source "drivers/usb/atm/Kconfig"
166
Florian Fainelli25e11ec2013-04-09 14:29:25 +0200167endif # USB
168
169source "drivers/usb/phy/Kconfig"
170
Linus Torvalds1da177e2005-04-16 15:20:36 -0700171source "drivers/usb/gadget/Kconfig"
172
Heikki Krogerusfab92882017-03-21 13:56:47 +0200173source "drivers/usb/typec/Kconfig"
174
Hans de Goedef6fb9ec2018-03-20 15:57:10 +0300175source "drivers/usb/roles/Kconfig"
176
Michal Sojka0cfbd322014-09-24 22:43:21 +0200177config USB_LED_TRIG
178 bool "USB LED Triggers"
Peter Chencb9c1cf2016-09-14 09:49:30 +0800179 depends on LEDS_CLASS && LEDS_TRIGGERS
180 select USB_COMMON
Michal Sojka0cfbd322014-09-24 22:43:21 +0200181 help
182 This option adds LED triggers for USB host and/or gadget activity.
183
184 Say Y here if you are working on a system with led-class supported
185 LEDs and you want to use them as activity indicators for USB host or
186 gadget.
187
Peter Chenad764c42016-08-16 17:33:25 +0800188config USB_ULPI_BUS
189 tristate "USB ULPI PHY interface support"
Peter Chencb9c1cf2016-09-14 09:49:30 +0800190 select USB_COMMON
Peter Chenad764c42016-08-16 17:33:25 +0800191 help
192 UTMI+ Low Pin Interface (ULPI) is specification for a commonly used
193 USB 2.0 PHY interface. The ULPI specification defines a standard set
194 of registers that can be used to detect the vendor and product which
195 allows ULPI to be handled as a bus. This module is the driver for that
196 bus.
197
198 The ULPI interfaces (the buses) are registered by the drivers for USB
199 controllers which support ULPI register access and have ULPI PHY
200 attached to them. The ULPI PHY drivers themselves are normal PHY
201 drivers.
202
203 ULPI PHYs provide often functions such as ADP sensing/probing (OTG
204 protocol) and USB charger detection.
205
206 To compile this driver as a module, choose M here: the module will
207 be called ulpi.
208
Jan Engelhardt04d06ad2007-05-10 23:04:13 -0700209endif # USB_SUPPORT