1# SPDX-License-Identifier: GPL-2.0
2#
3# USB Gadget support on a system involves
4#    (a) a peripheral controller, and
5#    (b) the gadget driver using it.
6#
7# NOTE:  Gadget support ** DOES NOT ** depend on host-side CONFIG_USB !!
8#
9#  - Host systems (like PCs) need CONFIG_USB (with "A" jacks).
10#  - Peripherals (like PDAs) need CONFIG_USB_GADGET (with "B" jacks).
11#  - Some systems have both kinds of controllers.
12#
13# With help from a special transceiver and a "Mini-AB" jack, systems with
14# both kinds of controller can also support "USB On-the-Go" (CONFIG_USB_OTG).
15#
16
17#
18# USB Peripheral Controller Support
19#
20# The order here is alphabetical, except that integrated controllers go
21# before discrete ones so they will be the initial/default value:
22#   - integrated/SOC controllers first
23#   - licensed IP used in both SOC and discrete versions
24#   - discrete ones (including all PCI-only controllers)
25#   - debug/dummy gadget+hcd is last.
26#
27menu "USB Peripheral Controller"
28
29#
30# Integrated controllers
31#
32
33config USB_AT91
34	tristate "Atmel AT91 USB Device Port"
35	depends on ARCH_AT91
36	depends on OF
37	help
38	   Many Atmel AT91 processors (such as the AT91RM2000) have a
39	   full speed USB Device Port with support for five configurable
40	   endpoints (plus endpoint zero).
41
42	   Say "y" to link the driver statically, or "m" to build a
43	   dynamically linked module called "at91_udc" and force all
44	   gadget drivers to also be dynamically linked.
45
46config USB_LPC32XX
47	tristate "LPC32XX USB Peripheral Controller"
48	depends on ARCH_LPC32XX || COMPILE_TEST
49	depends on I2C
50	select USB_ISP1301
51	help
52	   This option selects the USB device controller in the LPC32xx SoC.
53
54	   Say "y" to link the driver statically, or "m" to build a
55	   dynamically linked module called "lpc32xx_udc" and force all
56	   gadget drivers to also be dynamically linked.
57
58config USB_ATMEL_USBA
59	tristate "Atmel USBA"
60	depends on ARCH_AT91
61	help
62	  USBA is the integrated high-speed USB Device controller on some
63	  AT91SAM9 and AT91CAP9 processors from Atmel.
64
65	  The fifo_mode parameter is used to select endpoint allocation mode.
66	  fifo_mode = 0 is used to let the driver autoconfigure the endpoints.
67	  In this case, for ep1 2 banks are allocated if it works in isochronous
68	  mode and only 1 bank otherwise. For the rest of the endpoints
69	  only 1 bank is allocated.
70
71	  fifo_mode = 1 is a generic maximum fifo size (1024 bytes) configuration
72	  allowing the usage of ep1 - ep6
73
74	  fifo_mode = 2 is a generic performance maximum fifo size (1024 bytes)
75	  configuration allowing the usage of ep1 - ep3
76
77	  fifo_mode = 3 is a balanced performance configuration allowing the
78	  the usage of ep1 - ep8
79
80config USB_BCM63XX_UDC
81	tristate "Broadcom BCM63xx Peripheral Controller"
82	depends on BCM63XX
83	help
84	   Many Broadcom BCM63xx chipsets (such as the BCM6328) have a
85	   high speed USB Device Port with support for four fixed endpoints
86	   (plus endpoint zero).
87
88	   Say "y" to link the driver statically, or "m" to build a
89	   dynamically linked module called "bcm63xx_udc".
90
91config USB_FSL_USB2
92	tristate "Freescale Highspeed USB DR Peripheral Controller"
93	depends on FSL_SOC
94	help
95	   Some of Freescale PowerPC and i.MX processors have a High Speed
96	   Dual-Role(DR) USB controller, which supports device mode.
97
98	   The number of programmable endpoints is different through
99	   SOC revisions.
100
101	   Say "y" to link the driver statically, or "m" to build a
102	   dynamically linked module called "fsl_usb2_udc" and force
103	   all gadget drivers to also be dynamically linked.
104
105config USB_FUSB300
106	tristate "Faraday FUSB300 USB Peripheral Controller"
107	depends on !PHYS_ADDR_T_64BIT && HAS_DMA
108	help
109	   Faraday usb device controller FUSB300 driver
110
111config USB_GR_UDC
112	tristate "Aeroflex Gaisler GRUSBDC USB Peripheral Controller Driver"
113	depends on HAS_DMA
114	help
115	  Select this to support Aeroflex Gaisler GRUSBDC cores from the GRLIB
116	  VHDL IP core library.
117
118config USB_OMAP
119	tristate "OMAP USB Device Controller"
120	depends on ARCH_OMAP1
121	help
122	   Many Texas Instruments OMAP processors have flexible full
123	   speed USB device controllers, with support for up to 30
124	   endpoints (plus endpoint zero).  This driver supports the
125	   controller in the OMAP 1611, and should work with controllers
126	   in other OMAP processors too, given minor tweaks.
127
128	   Say "y" to link the driver statically, or "m" to build a
129	   dynamically linked module called "omap_udc" and force all
130	   gadget drivers to also be dynamically linked.
131
132config USB_PXA25X
133	tristate "PXA 25x or IXP 4xx"
134	depends on (ARCH_PXA && PXA25x) || ARCH_IXP4XX
135	depends on HAS_IOMEM
136	help
137	   Intel's PXA 25x series XScale ARM-5TE processors include
138	   an integrated full speed USB 1.1 device controller.  The
139	   controller in the IXP 4xx series is register-compatible.
140
141	   It has fifteen fixed-function endpoints, as well as endpoint
142	   zero (for control transfers).
143
144	   Say "y" to link the driver statically, or "m" to build a
145	   dynamically linked module called "pxa25x_udc" and force all
146	   gadget drivers to also be dynamically linked.
147
148# if there's only one gadget driver, using only two bulk endpoints,
149# don't waste memory for the other endpoints
150config USB_PXA25X_SMALL
151	depends on USB_PXA25X
152	bool
153	default n if USB_ETH_RNDIS
154	default y if USB_ZERO
155	default y if USB_ETH
156	default y if USB_G_SERIAL
157
158config USB_R8A66597
159	tristate "Renesas R8A66597 USB Peripheral Controller"
160	depends on HAS_DMA
161	help
162	   R8A66597 is a discrete USB host and peripheral controller chip that
163	   supports both full and high speed USB 2.0 data transfers.
164	   It has nine configurable endpoints, and endpoint zero.
165
166	   Say "y" to link the driver statically, or "m" to build a
167	   dynamically linked module called "r8a66597_udc" and force all
168	   gadget drivers to also be dynamically linked.
169
170config USB_RENESAS_USBHS_UDC
171	tristate 'Renesas USBHS controller'
172	depends on USB_RENESAS_USBHS
173	help
174	   Renesas USBHS is a discrete USB host and peripheral controller chip
175	   that supports both full and high speed USB 2.0 data transfers.
176	   It has nine or more configurable endpoints, and endpoint zero.
177
178	   Say "y" to link the driver statically, or "m" to build a
179	   dynamically linked module called "renesas_usbhs" and force all
180	   gadget drivers to also be dynamically linked.
181
182config USB_RZV2M_USB3DRD
183	tristate 'Renesas USB3.1 DRD controller'
184	depends on ARCH_R9A09G011 || COMPILE_TEST
185	help
186	   Renesas USB3.1 DRD controller is a USB DRD controller
187	   that supports both host and device switching.
188
189	   Say "y" to link the driver statically, or "m" to build a
190	   dynamically linked module called "rzv2m_usb3drd".
191
192config USB_RENESAS_USB3
193	tristate 'Renesas USB3.0 Peripheral controller'
194	depends on ARCH_RENESAS || COMPILE_TEST
195	depends on USB_RZV2M_USB3DRD || !USB_RZV2M_USB3DRD
196	depends on EXTCON
197	select USB_ROLE_SWITCH
198	help
199	   Renesas USB3.0 Peripheral controller is a USB peripheral controller
200	   that supports super, high, and full speed USB 3.0 data transfers.
201
202	   Say "y" to link the driver statically, or "m" to build a
203	   dynamically linked module called "renesas_usb3" and force all
204	   gadget drivers to also be dynamically linked.
205
206config USB_RENESAS_USBF
207	tristate 'Renesas USB Function controller'
208	depends on ARCH_RENESAS || COMPILE_TEST
209	help
210	   Renesas USB Function controller is a USB peripheral controller
211	   available on RZ/N1 Renesas SoCs.
212
213	   Say "y" to link the driver statically, or "m" to build a
214	   dynamically linked module called "renesas_usbf" and force all
215	   gadget drivers to also be dynamically linked.
216
217config USB_PXA27X
218	tristate "PXA 27x"
219	depends on HAS_IOMEM
220	help
221	   Intel's PXA 27x series XScale ARM v5TE processors include
222	   an integrated full speed USB 1.1 device controller.
223
224	   It has up to 23 endpoints, as well as endpoint zero (for
225	   control transfers).
226
227	   Say "y" to link the driver statically, or "m" to build a
228	   dynamically linked module called "pxa27x_udc" and force all
229	   gadget drivers to also be dynamically linked.
230
231config USB_MV_UDC
232	tristate "Marvell USB2.0 Device Controller"
233	depends on HAS_DMA
234	help
235	  Marvell Socs (including PXA and MMP series) include a high speed
236	  USB2.0 OTG controller, which can be configured as high speed or
237	  full speed USB peripheral.
238
239config USB_MV_U3D
240	depends on HAS_DMA
241	tristate "MARVELL PXA2128 USB 3.0 controller"
242	help
243	  MARVELL PXA2128 Processor series include a super speed USB3.0 device
244	  controller, which support super speed USB peripheral.
245
246config USB_SNP_CORE
247	depends on (USB_AMD5536UDC || USB_SNP_UDC_PLAT)
248	depends on HAS_DMA
249	tristate
250	help
251	  This enables core driver support for Synopsys USB 2.0 Device
252	  controller.
253
254	  This will be enabled when PCI or Platform driver for this UDC is
255	  selected. Currently, this will be enabled by USB_SNP_UDC_PLAT or
256	  USB_AMD5536UDC options.
257
258	  This IP is different to the High Speed OTG IP that can be enabled
259	  by selecting USB_DWC2 or USB_DWC3 options.
260
261config USB_SNP_UDC_PLAT
262	tristate "Synopsys USB 2.0 Device controller"
263	depends on USB_GADGET && OF && HAS_DMA
264	depends on EXTCON || EXTCON=n
265	select USB_SNP_CORE
266	default ARCH_BCM_IPROC
267	help
268	  This adds Platform Device support for Synopsys Designware core
269	  AHB subsystem USB2.0 Device Controller (UDC).
270
271	  This driver works with UDCs integrated into Broadcom's Northstar2
272	  and Cygnus SoCs.
273
274	  If unsure, say N.
275#
276# Controllers available in both integrated and discrete versions
277#
278
279config USB_M66592
280	tristate "Renesas M66592 USB Peripheral Controller"
281	depends on HAS_IOMEM
282	help
283	   M66592 is a discrete USB peripheral controller chip that
284	   supports both full and high speed USB 2.0 data transfers.
285	   It has seven configurable endpoints, and endpoint zero.
286
287	   Say "y" to link the driver statically, or "m" to build a
288	   dynamically linked module called "m66592_udc" and force all
289	   gadget drivers to also be dynamically linked.
290
291source "drivers/usb/gadget/udc/bdc/Kconfig"
292
293#
294# Controllers available only in discrete form (and all PCI controllers)
295#
296
297config USB_AMD5536UDC
298	tristate "AMD5536 UDC"
299	depends on USB_PCI && HAS_DMA
300	select USB_SNP_CORE
301	help
302	   The AMD5536 UDC is part of the AMD Geode CS5536, an x86 southbridge.
303	   It is a USB Highspeed DMA capable USB device controller. Beside ep0
304	   it provides 4 IN and 4 OUT endpoints (bulk or interrupt type).
305	   The UDC port supports OTG operation, and may be used as a host port
306	   if it's not being used to implement peripheral or OTG roles.
307
308	   This UDC is based on Synopsys USB device controller IP and selects
309	   CONFIG_USB_SNP_CORE option to build the core driver.
310
311	   Say "y" to link the driver statically, or "m" to build a
312	   dynamically linked module called "amd5536udc" and force all
313	   gadget drivers to also be dynamically linked.
314
315config USB_FSL_QE
316	tristate "Freescale QE/CPM USB Device Controller"
317	depends on FSL_SOC && (QUICC_ENGINE || CPM)
318	depends on !64BIT || BROKEN
319	help
320	   Some of Freescale PowerPC processors have a Full Speed
321	   QE/CPM2 USB controller, which support device mode with 4
322	   programmable endpoints. This driver supports the
323	   controller in the MPC8360 and MPC8272, and should work with
324	   controllers having QE or CPM2, given minor tweaks.
325
326	   Set CONFIG_USB_GADGET to "m" to build this driver as a
327	   dynamically linked module called "fsl_qe_udc".
328
329config USB_NET2272
330	depends on HAS_IOMEM
331	tristate "PLX NET2272"
332	help
333	  PLX NET2272 is a USB peripheral controller which supports
334	  both full and high speed USB 2.0 data transfers.
335
336	  It has three configurable endpoints, as well as endpoint zero
337	  (for control transfer).
338	  Say "y" to link the driver statically, or "m" to build a
339	  dynamically linked module called "net2272" and force all
340	  gadget drivers to also be dynamically linked.
341
342config USB_NET2272_DMA
343	bool "Support external DMA controller"
344	depends on USB_NET2272 && HAS_DMA
345	help
346	  The NET2272 part can optionally support an external DMA
347	  controller, but your board has to have support in the
348	  driver itself.
349
350	  If unsure, say "N" here.  The driver works fine in PIO mode.
351
352config USB_NET2280
353	tristate "NetChip NET228x / PLX USB3x8x"
354	depends on USB_PCI
355	help
356	   NetChip 2280 / 2282 is a PCI based USB peripheral controller which
357	   supports both full and high speed USB 2.0 data transfers.
358
359	   It has six configurable endpoints, as well as endpoint zero
360	   (for control transfers) and several endpoints with dedicated
361	   functions.
362
363	   PLX 2380 is a PCIe version of the PLX 2380.
364
365	   PLX 3380 / 3382 is a PCIe based USB peripheral controller which
366	   supports full, high speed USB 2.0 and super speed USB 3.0
367	   data transfers.
368
369	   It has eight configurable endpoints, as well as endpoint zero
370	   (for control transfers) and several endpoints with dedicated
371	   functions.
372
373	   Say "y" to link the driver statically, or "m" to build a
374	   dynamically linked module called "net2280" and force all
375	   gadget drivers to also be dynamically linked.
376
377config USB_GOKU
378	tristate "Toshiba TC86C001 'Goku-S'"
379	depends on USB_PCI
380	help
381	   The Toshiba TC86C001 is a PCI device which includes controllers
382	   for full speed USB devices, IDE, I2C, SIO, plus a USB host (OHCI).
383
384	   The device controller has three configurable (bulk or interrupt)
385	   endpoints, plus endpoint zero (for control transfers).
386
387	   Say "y" to link the driver statically, or "m" to build a
388	   dynamically linked module called "goku_udc" and to force all
389	   gadget drivers to also be dynamically linked.
390
391config USB_EG20T
392	tristate "Intel QUARK X1000/EG20T PCH/LAPIS Semiconductor IOH(ML7213/ML7831) UDC"
393	depends on USB_PCI
394	help
395	  This is a USB device driver for EG20T PCH.
396	  EG20T PCH is the platform controller hub that is used in Intel's
397	  general embedded platform. EG20T PCH has USB device interface.
398	  Using this interface, it is able to access system devices connected
399	  to USB device.
400	  This driver enables USB device function.
401	  USB device is a USB peripheral controller which
402	  supports both full and high speed USB 2.0 data transfers.
403	  This driver supports both control transfer and bulk transfer modes.
404	  This driver dose not support interrupt transfer or isochronous
405	  transfer modes.
406
407	  This driver also can be used for LAPIS Semiconductor's ML7213 which is
408	  for IVI(In-Vehicle Infotainment) use.
409	  ML7831 is for general purpose use.
410	  ML7213/ML7831 is companion chip for Intel Atom E6xx series.
411	  ML7213/ML7831 is completely compatible for Intel EG20T PCH.
412
413	  This driver can be used with Intel's Quark X1000 SOC platform
414
415config USB_GADGET_XILINX
416	tristate "Xilinx USB Driver"
417	depends on HAS_DMA
418	depends on OF
419	help
420	  USB peripheral controller driver for Xilinx USB2 device.
421	  Xilinx USB2 device is a soft IP which supports both full
422	  and high speed USB 2.0 data transfers. It has seven configurable
423	  endpoints(bulk or interrupt or isochronous), as well as
424	  endpoint zero(for control transfers).
425
426	  Say "y" to link the driver statically, or "m" to build a
427	  dynamically linked module called "udc-xilinx" and force all
428	  gadget drivers to also be dynamically linked.
429
430config USB_MAX3420_UDC
431	tristate "MAX3420 (USB-over-SPI) support"
432	depends on SPI
433	help
434	  The Maxim MAX3420 chip supports USB2.0 full-speed peripheral mode.
435	  The MAX3420 is run by SPI interface, and hence the dependency.
436
437	  To compile this driver as a module, choose M here: the module will
438	  be called max3420_udc
439
440config USB_TEGRA_XUDC
441	tristate "NVIDIA Tegra Superspeed USB 3.0 Device Controller"
442	depends on ARCH_TEGRA || COMPILE_TEST
443	depends on PHY_TEGRA_XUSB
444	help
445	 Enables NVIDIA Tegra USB 3.0 device mode controller driver.
446
447	 Say "y" to link the driver statically, or "m" to build a
448	 dynamically linked module called "tegra_xudc" and force all
449	 gadget drivers to also be dynamically linked.
450
451config USB_ASPEED_UDC
452	tristate "Aspeed UDC driver support"
453	depends on ARCH_ASPEED || COMPILE_TEST
454	depends on USB_LIBCOMPOSITE
455	help
456	  Enables Aspeed USB2.0 Device Controller driver for AST260x
457	  family SoCs. The controller supports 1 control endpoint and
458	  4 programmable endpoints.
459
460	  Say "y" to link the driver statically, or "m" to build a
461	  dynamically linked module called "aspeed_udc" and force all
462	  gadget drivers to also be dynamically linked.
463
464source "drivers/usb/gadget/udc/aspeed-vhub/Kconfig"
465
466source "drivers/usb/gadget/udc/cdns2/Kconfig"
467
468#
469# LAST -- dummy/emulated controller
470#
471
472config USB_DUMMY_HCD
473	tristate "Dummy HCD (DEVELOPMENT)"
474	depends on USB=y || (USB=m && USB_GADGET=m)
475	help
476	  This host controller driver emulates USB, looping all data transfer
477	  requests back to a USB "gadget driver" in the same host.  The host
478	  side is the controller; the gadget side is the device.  Gadget drivers
479	  can be high, full, or low speed; and they have access to endpoints
480	  like those from NET2280, PXA2xx, or SA1100 hardware.
481
482	  This may help in some stages of creating a driver to embed in a
483	  Linux device, since it lets you debug several parts of the gadget
484	  driver without its hardware or drivers being involved.
485
486	  Since such a gadget side driver needs to interoperate with a host
487	  side Linux-USB device driver, this may help to debug both sides
488	  of a USB protocol stack.
489
490	  Say "y" to link the driver statically, or "m" to build a
491	  dynamically linked module called "dummy_hcd" and force all
492	  gadget drivers to also be dynamically linked.
493
494# NOTE:  Please keep dummy_hcd LAST so that "real hardware" appears
495# first and will be selected by default.
496
497endmenu
498