Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux
[platform/kernel/linux-rpi.git] / drivers / usb / Kconfig
1 # SPDX-License-Identifier: GPL-2.0
2 #
3 # USB device configuration
4 #
5
6 config USB_OHCI_BIG_ENDIAN_DESC
7         bool
8
9 config USB_OHCI_BIG_ENDIAN_MMIO
10         bool
11
12 config USB_OHCI_LITTLE_ENDIAN
13         bool
14         default n if PPC_MPC52xx
15         default y
16
17 config USB_EHCI_BIG_ENDIAN_MMIO
18         bool
19
20 config USB_EHCI_BIG_ENDIAN_DESC
21         bool
22
23 config USB_UHCI_BIG_ENDIAN_MMIO
24         bool
25
26 config USB_UHCI_BIG_ENDIAN_DESC
27         bool
28
29 menuconfig 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
37 if USB_SUPPORT
38
39 source "drivers/usb/common/Kconfig"
40
41 config USB_ARCH_HAS_HCD
42         def_bool y
43
44 config USB
45         tristate "Support for Host-side USB"
46         depends on USB_ARCH_HAS_HCD
47         select GENERIC_ALLOCATOR
48         select USB_COMMON
49         select NLS  # for UTF-8 strings
50         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.rst>.
78
79           To compile this driver as a module, choose M here: the
80           module will be called usbcore.
81
82 config USB_PCI
83         bool "PCI based USB host interface"
84         depends on PCI
85         default y
86         help
87           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.
90
91           If you have such a device you may say N here and PCI related code
92           will not be built in the USB driver.
93
94 if USB
95
96 source "drivers/usb/core/Kconfig"
97
98 source "drivers/usb/mon/Kconfig"
99
100 source "drivers/usb/host/Kconfig"
101
102 source "drivers/usb/renesas_usbhs/Kconfig"
103
104 source "drivers/usb/class/Kconfig"
105
106 source "drivers/usb/storage/Kconfig"
107
108 source "drivers/usb/image/Kconfig"
109
110 source "drivers/usb/usbip/Kconfig"
111
112 endif
113
114 comment "USB dual-mode controller drivers"
115
116 source "drivers/usb/cdns3/Kconfig"
117
118 source "drivers/usb/fotg210/Kconfig"
119
120 source "drivers/usb/mtu3/Kconfig"
121
122 source "drivers/usb/musb/Kconfig"
123
124 source "drivers/usb/dwc3/Kconfig"
125
126 source "drivers/usb/dwc2/Kconfig"
127
128 source "drivers/usb/chipidea/Kconfig"
129
130 source "drivers/usb/isp1760/Kconfig"
131
132 comment "USB port drivers"
133
134 if USB
135
136 config USB_USS720
137         tristate "USS720 parport driver"
138         depends on PARPORT
139         select PARPORT_NOT_PC
140         help
141           This driver is for USB parallel port adapters that use the Lucent
142           Technologies USS-720 chip. These cables are plugged into your USB
143           port and provide USB compatibility to peripherals designed with
144           parallel port interfaces.
145
146           The chip has two modes: automatic mode and manual mode. In automatic
147           mode, it looks to the computer like a standard USB printer. Only
148           printers may be connected to the USS-720 in this mode. The generic
149           USB printer driver ("USB Printer support", above) may be used in
150           that mode, and you can say N here if you want to use the chip only
151           in this mode.
152
153           Manual mode is not limited to printers, any parallel port
154           device should work. This driver utilizes manual mode.
155           Note however that some operations are three orders of magnitude
156           slower than on a PCI/ISA Parallel Port, so timing critical
157           applications might not work.
158
159           Say Y here if you own an USS-720 USB->Parport cable and intend to
160           connect anything other than a printer to it.
161
162           To compile this driver as a module, choose M here: the
163           module will be called uss720.
164
165 source "drivers/usb/serial/Kconfig"
166
167 source "drivers/usb/misc/Kconfig"
168
169 source "drivers/usb/atm/Kconfig"
170
171 endif # USB
172
173 source "drivers/usb/phy/Kconfig"
174
175 source "drivers/usb/gadget/Kconfig"
176
177 source "drivers/usb/typec/Kconfig"
178
179 source "drivers/usb/roles/Kconfig"
180
181 endif # USB_SUPPORT