2 # USB Gadget support on a system involves
3 # (a) a peripheral controller, and
4 # (b) the gadget driver using it.
6 # NOTE: Gadget support ** DOES NOT ** depend on host-side CONFIG_USB !!
8 # - Host systems (like PCs) need CONFIG_USB (with "A" jacks).
9 # - Peripherals (like PDAs) need CONFIG_USB_GADGET (with "B" jacks).
10 # - Some systems have both kinds of controllers.
12 # With help from a special transceiver and a "Mini-AB" jack, systems with
13 # both kinds of controller can also support "USB On-the-Go" (CONFIG_USB_OTG).
17 # USB Peripheral Controller Support
19 # The order here is alphabetical, except that integrated controllers go
20 # before discrete ones so they will be the initial/default value:
21 # - integrated/SOC controllers first
22 # - licensed IP used in both SOC and discrete versions
23 # - discrete ones (including all PCI-only controllers)
24 # - debug/dummy gadget+hcd is last.
26 menu "USB Peripheral Controller"
29 # Integrated controllers
33 tristate "Atmel AT91 USB Device Port"
35 depends on OF || COMPILE_TEST
37 Many Atmel AT91 processors (such as the AT91RM2000) have a
38 full speed USB Device Port with support for five configurable
39 endpoints (plus endpoint zero).
41 Say "y" to link the driver statically, or "m" to build a
42 dynamically linked module called "at91_udc" and force all
43 gadget drivers to also be dynamically linked.
46 tristate "LPC32XX USB Peripheral Controller"
47 depends on ARCH_LPC32XX && I2C
50 This option selects the USB device controller in the LPC32xx SoC.
52 Say "y" to link the driver statically, or "m" to build a
53 dynamically linked module called "lpc32xx_udc" and force all
54 gadget drivers to also be dynamically linked.
60 USBA is the integrated high-speed USB Device controller on
61 the AT32AP700x, some AT91SAM9 and AT91CAP9 processors from Atmel.
63 The fifo_mode parameter is used to select endpoint allocation mode.
64 fifo_mode = 0 is used to let the driver autoconfigure the endpoints.
65 In this case, for ep1 2 banks are allocated if it works in isochronous
66 mode and only 1 bank otherwise. For the rest of the endpoints
67 only 1 bank is allocated.
69 fifo_mode = 1 is a generic maximum fifo size (1024 bytes) configuration
70 allowing the usage of ep1 - ep6
72 fifo_mode = 2 is a generic performance maximum fifo size (1024 bytes)
73 configuration allowing the usage of ep1 - ep3
75 fifo_mode = 3 is a balanced performance configuration allowing the
76 the usage of ep1 - ep8
78 config USB_BCM63XX_UDC
79 tristate "Broadcom BCM63xx Peripheral Controller"
82 Many Broadcom BCM63xx chipsets (such as the BCM6328) have a
83 high speed USB Device Port with support for four fixed endpoints
86 Say "y" to link the driver statically, or "m" to build a
87 dynamically linked module called "bcm63xx_udc".
90 tristate "Freescale Highspeed USB DR Peripheral Controller"
91 depends on FSL_SOC || ARCH_MXC
93 Some of Freescale PowerPC and i.MX processors have a High Speed
94 Dual-Role(DR) USB controller, which supports device mode.
96 The number of programmable endpoints is different through
99 Say "y" to link the driver statically, or "m" to build a
100 dynamically linked module called "fsl_usb2_udc" and force
101 all gadget drivers to also be dynamically linked.
104 tristate "Faraday FUSB300 USB Peripheral Controller"
105 depends on !PHYS_ADDR_T_64BIT && HAS_DMA
107 Faraday usb device controller FUSB300 driver
109 config USB_FOTG210_UDC
111 tristate "Faraday FOTG210 USB Peripheral Controller"
113 Faraday USB2.0 OTG controller which can be configured as
114 high speed or full speed USB device. This driver supppors
115 Bulk Transfer so far.
117 Say "y" to link the driver statically, or "m" to build a
118 dynamically linked module called "fotg210_udc".
121 tristate "Aeroflex Gaisler GRUSBDC USB Peripheral Controller Driver"
124 Select this to support Aeroflex Gaisler GRUSBDC cores from the GRLIB
125 VHDL IP core library.
128 tristate "OMAP USB Device Controller"
129 depends on ARCH_OMAP1
130 depends on ISP1301_OMAP || !(MACH_OMAP_H2 || MACH_OMAP_H3)
132 Many Texas Instruments OMAP processors have flexible full
133 speed USB device controllers, with support for up to 30
134 endpoints (plus endpoint zero). This driver supports the
135 controller in the OMAP 1611, and should work with controllers
136 in other OMAP processors too, given minor tweaks.
138 Say "y" to link the driver statically, or "m" to build a
139 dynamically linked module called "omap_udc" and force all
140 gadget drivers to also be dynamically linked.
143 tristate "PXA 25x or IXP 4xx"
144 depends on (ARCH_PXA && PXA25x) || ARCH_IXP4XX
147 Intel's PXA 25x series XScale ARM-5TE processors include
148 an integrated full speed USB 1.1 device controller. The
149 controller in the IXP 4xx series is register-compatible.
151 It has fifteen fixed-function endpoints, as well as endpoint
152 zero (for control transfers).
154 Say "y" to link the driver statically, or "m" to build a
155 dynamically linked module called "pxa25x_udc" and force all
156 gadget drivers to also be dynamically linked.
158 # if there's only one gadget driver, using only two bulk endpoints,
159 # don't waste memory for the other endpoints
160 config USB_PXA25X_SMALL
161 depends on USB_PXA25X
163 default n if USB_ETH_RNDIS
164 default y if USB_ZERO
166 default y if USB_G_SERIAL
169 tristate "Renesas R8A66597 USB Peripheral Controller"
172 R8A66597 is a discrete USB host and peripheral controller chip that
173 supports both full and high speed USB 2.0 data transfers.
174 It has nine configurable endpoints, and endpoint zero.
176 Say "y" to link the driver statically, or "m" to build a
177 dynamically linked module called "r8a66597_udc" and force all
178 gadget drivers to also be dynamically linked.
180 config USB_RENESAS_USBHS_UDC
181 tristate 'Renesas USBHS controller'
182 depends on USB_RENESAS_USBHS && HAS_DMA
184 Renesas USBHS is a discrete USB host and peripheral controller chip
185 that supports both full and high speed USB 2.0 data transfers.
186 It has nine or more configurable endpoints, and endpoint zero.
188 Say "y" to link the driver statically, or "m" to build a
189 dynamically linked module called "renesas_usbhs" and force all
190 gadget drivers to also be dynamically linked.
192 config USB_RENESAS_USB3
193 tristate 'Renesas USB3.0 Peripheral controller'
194 depends on ARCH_RENESAS || COMPILE_TEST
195 depends on EXTCON && HAS_DMA
197 Renesas USB3.0 Peripheral controller is a USB peripheral controller
198 that supports super, high, and full speed USB 3.0 data transfers.
200 Say "y" to link the driver statically, or "m" to build a
201 dynamically linked module called "renesas_usb3" and force all
202 gadget drivers to also be dynamically linked.
208 Intel's PXA 27x series XScale ARM v5TE processors include
209 an integrated full speed USB 1.1 device controller.
211 It has up to 23 endpoints, as well as endpoint zero (for
214 Say "y" to link the driver statically, or "m" to build a
215 dynamically linked module called "pxa27x_udc" and force all
216 gadget drivers to also be dynamically linked.
219 tristate "S3C2410 USB Device Controller"
220 depends on ARCH_S3C24XX
222 Samsung's S3C2410 is an ARM-4 processor with an integrated
223 full speed USB 1.1 device controller. It has 4 configurable
224 endpoints, as well as endpoint zero (for control transfers).
226 This driver has been tested on the S3C2410, S3C2412, and
229 config USB_S3C2410_DEBUG
230 bool "S3C2410 udc debug messages"
231 depends on USB_S3C2410
234 tristate "S3C2416, S3C2443 and S3C2450 USB Device Controller"
235 depends on ARCH_S3C24XX
237 Samsung's S3C2416, S3C2443 and S3C2450 is an ARM9 based SoC
238 integrated with dual speed USB 2.0 device controller. It has
239 8 endpoints, as well as endpoint zero.
241 This driver has been tested on S3C2416 and S3C2450 processors.
244 tristate "Marvell USB2.0 Device Controller"
247 Marvell Socs (including PXA and MMP series) include a high speed
248 USB2.0 OTG controller, which can be configured as high speed or
249 full speed USB peripheral.
253 tristate "MARVELL PXA2128 USB 3.0 controller"
255 MARVELL PXA2128 Processor series include a super speed USB3.0 device
256 controller, which support super speed USB peripheral.
259 depends on (USB_AMD5536UDC || USB_SNP_UDC_PLAT)
263 This enables core driver support for Synopsys USB 2.0 Device
266 This will be enabled when PCI or Platform driver for this UDC is
267 selected. Currently, this will be enabled by USB_SNP_UDC_PLAT or
268 USB_AMD5536UDC options.
270 This IP is different to the High Speed OTG IP that can be enabled
271 by selecting USB_DWC2 or USB_DWC3 options.
273 config USB_SNP_UDC_PLAT
274 tristate "Synopsys USB 2.0 Device controller"
275 depends on USB_GADGET && OF && HAS_DMA
276 depends on EXTCON || EXTCON=n
277 select USB_GADGET_DUALSPEED
279 default ARCH_BCM_IPROC
281 This adds Platform Device support for Synopsys Designware core
282 AHB subsystem USB2.0 Device Controller (UDC).
284 This driver works with UDCs integrated into Broadcom's Northstar2
289 # Controllers available in both integrated and discrete versions
293 tristate "Renesas M66592 USB Peripheral Controller"
296 M66592 is a discrete USB peripheral controller chip that
297 supports both full and high speed USB 2.0 data transfers.
298 It has seven configurable endpoints, and endpoint zero.
300 Say "y" to link the driver statically, or "m" to build a
301 dynamically linked module called "m66592_udc" and force all
302 gadget drivers to also be dynamically linked.
304 source "drivers/usb/gadget/udc/bdc/Kconfig"
307 # Controllers available only in discrete form (and all PCI controllers)
310 config USB_AMD5536UDC
311 tristate "AMD5536 UDC"
315 The AMD5536 UDC is part of the AMD Geode CS5536, an x86 southbridge.
316 It is a USB Highspeed DMA capable USB device controller. Beside ep0
317 it provides 4 IN and 4 OUT endpoints (bulk or interrupt type).
318 The UDC port supports OTG operation, and may be used as a host port
319 if it's not being used to implement peripheral or OTG roles.
321 This UDC is based on Synopsys USB device controller IP and selects
322 CONFIG_USB_SNP_CORE option to build the core driver.
324 Say "y" to link the driver statically, or "m" to build a
325 dynamically linked module called "amd5536udc" and force all
326 gadget drivers to also be dynamically linked.
329 tristate "Freescale QE/CPM USB Device Controller"
330 depends on FSL_SOC && (QUICC_ENGINE || CPM)
332 Some of Freescale PowerPC processors have a Full Speed
333 QE/CPM2 USB controller, which support device mode with 4
334 programmable endpoints. This driver supports the
335 controller in the MPC8360 and MPC8272, and should work with
336 controllers having QE or CPM2, given minor tweaks.
338 Set CONFIG_USB_GADGET to "m" to build this driver as a
339 dynamically linked module called "fsl_qe_udc".
343 tristate "PLX NET2272"
345 PLX NET2272 is a USB peripheral controller which supports
346 both full and high speed USB 2.0 data transfers.
348 It has three configurable endpoints, as well as endpoint zero
349 (for control transfer).
350 Say "y" to link the driver statically, or "m" to build a
351 dynamically linked module called "net2272" and force all
352 gadget drivers to also be dynamically linked.
354 config USB_NET2272_DMA
355 bool "Support external DMA controller"
356 depends on USB_NET2272 && HAS_DMA
358 The NET2272 part can optionally support an external DMA
359 controller, but your board has to have support in the
362 If unsure, say "N" here. The driver works fine in PIO mode.
365 tristate "NetChip NET228x / PLX USB3x8x"
368 NetChip 2280 / 2282 is a PCI based USB peripheral controller which
369 supports both full and high speed USB 2.0 data transfers.
371 It has six configurable endpoints, as well as endpoint zero
372 (for control transfers) and several endpoints with dedicated
375 PLX 2380 is a PCIe version of the PLX 2380.
377 PLX 3380 / 3382 is a PCIe based USB peripheral controller which
378 supports full, high speed USB 2.0 and super speed USB 3.0
381 It has eight configurable endpoints, as well as endpoint zero
382 (for control transfers) and several endpoints with dedicated
385 Say "y" to link the driver statically, or "m" to build a
386 dynamically linked module called "net2280" and force all
387 gadget drivers to also be dynamically linked.
390 tristate "Toshiba TC86C001 'Goku-S'"
393 The Toshiba TC86C001 is a PCI device which includes controllers
394 for full speed USB devices, IDE, I2C, SIO, plus a USB host (OHCI).
396 The device controller has three configurable (bulk or interrupt)
397 endpoints, plus endpoint zero (for control transfers).
399 Say "y" to link the driver statically, or "m" to build a
400 dynamically linked module called "goku_udc" and to force all
401 gadget drivers to also be dynamically linked.
404 tristate "Intel QUARK X1000/EG20T PCH/LAPIS Semiconductor IOH(ML7213/ML7831) UDC"
407 This is a USB device driver for EG20T PCH.
408 EG20T PCH is the platform controller hub that is used in Intel's
409 general embedded platform. EG20T PCH has USB device interface.
410 Using this interface, it is able to access system devices connected
412 This driver enables USB device function.
413 USB device is a USB peripheral controller which
414 supports both full and high speed USB 2.0 data transfers.
415 This driver supports both control transfer and bulk transfer modes.
416 This driver dose not support interrupt transfer or isochronous
419 This driver also can be used for LAPIS Semiconductor's ML7213 which is
420 for IVI(In-Vehicle Infotainment) use.
421 ML7831 is for general purpose use.
422 ML7213/ML7831 is companion chip for Intel Atom E6xx series.
423 ML7213/ML7831 is completely compatible for Intel EG20T PCH.
425 This driver can be used with Intel's Quark X1000 SOC platform
427 config USB_GADGET_XILINX
428 tristate "Xilinx USB Driver"
430 depends on OF || COMPILE_TEST
432 USB peripheral controller driver for Xilinx USB2 device.
433 Xilinx USB2 device is a soft IP which supports both full
434 and high speed USB 2.0 data transfers. It has seven configurable
435 endpoints(bulk or interrupt or isochronous), as well as
436 endpoint zero(for control transfers).
438 Say "y" to link the driver statically, or "m" to build a
439 dynamically linked module called "udc-xilinx" and force all
440 gadget drivers to also be dynamically linked.
443 # LAST -- dummy/emulated controller
447 tristate "Dummy HCD (DEVELOPMENT)"
448 depends on USB=y || (USB=m && USB_GADGET=m)
450 This host controller driver emulates USB, looping all data transfer
451 requests back to a USB "gadget driver" in the same host. The host
452 side is the master; the gadget side is the slave. Gadget drivers
453 can be high, full, or low speed; and they have access to endpoints
454 like those from NET2280, PXA2xx, or SA1100 hardware.
456 This may help in some stages of creating a driver to embed in a
457 Linux device, since it lets you debug several parts of the gadget
458 driver without its hardware or drivers being involved.
460 Since such a gadget side driver needs to interoperate with a host
461 side Linux-USB device driver, this may help to debug both sides
462 of a USB protocol stack.
464 Say "y" to link the driver statically, or "m" to build a
465 dynamically linked module called "dummy_hcd" and force all
466 gadget drivers to also be dynamically linked.
468 # NOTE: Please keep dummy_hcd LAST so that "real hardware" appears
469 # first and will be selected by default.