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.
58 depends on ((AVR32 && !OF) || ARCH_AT91)
60 USBA is the integrated high-speed USB Device controller on
61 the AT32AP700x, some AT91SAM9 and AT91CAP9 processors from Atmel.
63 config USB_BCM63XX_UDC
64 tristate "Broadcom BCM63xx Peripheral Controller"
67 Many Broadcom BCM63xx chipsets (such as the BCM6328) have a
68 high speed USB Device Port with support for four fixed endpoints
71 Say "y" to link the driver statically, or "m" to build a
72 dynamically linked module called "bcm63xx_udc".
75 tristate "Freescale Highspeed USB DR Peripheral Controller"
76 depends on FSL_SOC || ARCH_MXC
77 select USB_FSL_MPH_DR_OF if OF
79 Some of Freescale PowerPC and i.MX processors have a High Speed
80 Dual-Role(DR) USB controller, which supports device mode.
82 The number of programmable endpoints is different through
85 Say "y" to link the driver statically, or "m" to build a
86 dynamically linked module called "fsl_usb2_udc" and force
87 all gadget drivers to also be dynamically linked.
90 tristate "Faraday FUSB300 USB Peripheral Controller"
91 depends on !PHYS_ADDR_T_64BIT && HAS_DMA
93 Faraday usb device controller FUSB300 driver
95 config USB_FOTG210_UDC
97 tristate "Faraday FOTG210 USB Peripheral Controller"
99 Faraday USB2.0 OTG controller which can be configured as
100 high speed or full speed USB device. This driver supppors
101 Bulk Transfer so far.
103 Say "y" to link the driver statically, or "m" to build a
104 dynamically linked module called "fotg210_udc".
107 tristate "Aeroflex Gaisler GRUSBDC USB Peripheral Controller Driver"
110 Select this to support Aeroflex Gaisler GRUSBDC cores from the GRLIB
111 VHDL IP core library.
114 tristate "OMAP USB Device Controller"
115 depends on ARCH_OMAP1
116 depends on ISP1301_OMAP || !(MACH_OMAP_H2 || MACH_OMAP_H3)
118 Many Texas Instruments OMAP processors have flexible full
119 speed USB device controllers, with support for up to 30
120 endpoints (plus endpoint zero). This driver supports the
121 controller in the OMAP 1611, and should work with controllers
122 in other OMAP processors too, given minor tweaks.
124 Say "y" to link the driver statically, or "m" to build a
125 dynamically linked module called "omap_udc" and force all
126 gadget drivers to also be dynamically linked.
129 tristate "PXA 25x or IXP 4xx"
130 depends on (ARCH_PXA && PXA25x) || ARCH_IXP4XX
132 Intel's PXA 25x series XScale ARM-5TE processors include
133 an integrated full speed USB 1.1 device controller. The
134 controller in the IXP 4xx series is register-compatible.
136 It has fifteen fixed-function endpoints, as well as endpoint
137 zero (for control transfers).
139 Say "y" to link the driver statically, or "m" to build a
140 dynamically linked module called "pxa25x_udc" and force all
141 gadget drivers to also be dynamically linked.
143 # if there's only one gadget driver, using only two bulk endpoints,
144 # don't waste memory for the other endpoints
145 config USB_PXA25X_SMALL
146 depends on USB_PXA25X
148 default n if USB_ETH_RNDIS
149 default y if USB_ZERO
151 default y if USB_G_SERIAL
154 tristate "Renesas R8A66597 USB Peripheral Controller"
157 R8A66597 is a discrete USB host and peripheral controller chip that
158 supports both full and high speed USB 2.0 data transfers.
159 It has nine configurable endpoints, and endpoint zero.
161 Say "y" to link the driver statically, or "m" to build a
162 dynamically linked module called "r8a66597_udc" and force all
163 gadget drivers to also be dynamically linked.
165 config USB_RENESAS_USBHS_UDC
166 tristate 'Renesas USBHS controller'
167 depends on USB_RENESAS_USBHS && HAS_DMA
169 Renesas USBHS is a discrete USB host and peripheral controller chip
170 that supports both full and high speed USB 2.0 data transfers.
171 It has nine or more configurable endpoints, and endpoint zero.
173 Say "y" to link the driver statically, or "m" to build a
174 dynamically linked module called "renesas_usbhs" and force all
175 gadget drivers to also be dynamically linked.
177 config USB_RENESAS_USB3
178 tristate 'Renesas USB3.0 Peripheral controller'
179 depends on ARCH_SHMOBILE || COMPILE_TEST
181 Renesas USB3.0 Peripheral controller is a USB peripheral controller
182 that supports super, high, and full speed USB 3.0 data transfers.
184 Say "y" to link the driver statically, or "m" to build a
185 dynamically linked module called "renesas_usb3" and force all
186 gadget drivers to also be dynamically linked.
191 Intel's PXA 27x series XScale ARM v5TE processors include
192 an integrated full speed USB 1.1 device controller.
194 It has up to 23 endpoints, as well as endpoint zero (for
197 Say "y" to link the driver statically, or "m" to build a
198 dynamically linked module called "pxa27x_udc" and force all
199 gadget drivers to also be dynamically linked.
202 tristate "S3C2410 USB Device Controller"
203 depends on ARCH_S3C24XX
205 Samsung's S3C2410 is an ARM-4 processor with an integrated
206 full speed USB 1.1 device controller. It has 4 configurable
207 endpoints, as well as endpoint zero (for control transfers).
209 This driver has been tested on the S3C2410, S3C2412, and
212 config USB_S3C2410_DEBUG
213 bool "S3C2410 udc debug messages"
214 depends on USB_S3C2410
217 tristate "S3C2416, S3C2443 and S3C2450 USB Device Controller"
218 depends on ARCH_S3C24XX
220 Samsung's S3C2416, S3C2443 and S3C2450 is an ARM9 based SoC
221 integrated with dual speed USB 2.0 device controller. It has
222 8 endpoints, as well as endpoint zero.
224 This driver has been tested on S3C2416 and S3C2450 processors.
227 tristate "Marvell USB2.0 Device Controller"
230 Marvell Socs (including PXA and MMP series) include a high speed
231 USB2.0 OTG controller, which can be configured as high speed or
232 full speed USB peripheral.
236 tristate "MARVELL PXA2128 USB 3.0 controller"
238 MARVELL PXA2128 Processor series include a super speed USB3.0 device
239 controller, which support super speed USB peripheral.
242 # Controllers available in both integrated and discrete versions
246 tristate "Renesas M66592 USB Peripheral Controller"
248 M66592 is a discrete USB peripheral controller chip that
249 supports both full and high speed USB 2.0 data transfers.
250 It has seven configurable endpoints, and endpoint zero.
252 Say "y" to link the driver statically, or "m" to build a
253 dynamically linked module called "m66592_udc" and force all
254 gadget drivers to also be dynamically linked.
256 source "drivers/usb/gadget/udc/bdc/Kconfig"
259 # Controllers available only in discrete form (and all PCI controllers)
262 config USB_AMD5536UDC
263 tristate "AMD5536 UDC"
266 The AMD5536 UDC is part of the AMD Geode CS5536, an x86 southbridge.
267 It is a USB Highspeed DMA capable USB device controller. Beside ep0
268 it provides 4 IN and 4 OUT endpoints (bulk or interrupt type).
269 The UDC port supports OTG operation, and may be used as a host port
270 if it's not being used to implement peripheral or OTG roles.
272 Say "y" to link the driver statically, or "m" to build a
273 dynamically linked module called "amd5536udc" and force all
274 gadget drivers to also be dynamically linked.
277 tristate "Freescale QE/CPM USB Device Controller"
278 depends on FSL_SOC && (QUICC_ENGINE || CPM)
280 Some of Freescale PowerPC processors have a Full Speed
281 QE/CPM2 USB controller, which support device mode with 4
282 programmable endpoints. This driver supports the
283 controller in the MPC8360 and MPC8272, and should work with
284 controllers having QE or CPM2, given minor tweaks.
286 Set CONFIG_USB_GADGET to "m" to build this driver as a
287 dynamically linked module called "fsl_qe_udc".
290 tristate "PLX NET2272"
292 PLX NET2272 is a USB peripheral controller which supports
293 both full and high speed USB 2.0 data transfers.
295 It has three configurable endpoints, as well as endpoint zero
296 (for control transfer).
297 Say "y" to link the driver statically, or "m" to build a
298 dynamically linked module called "net2272" and force all
299 gadget drivers to also be dynamically linked.
301 config USB_NET2272_DMA
302 bool "Support external DMA controller"
303 depends on USB_NET2272 && HAS_DMA
305 The NET2272 part can optionally support an external DMA
306 controller, but your board has to have support in the
309 If unsure, say "N" here. The driver works fine in PIO mode.
312 tristate "NetChip 228x / PLX USB338x"
315 NetChip 2280 / 2282 is a PCI based USB peripheral controller which
316 supports both full and high speed USB 2.0 data transfers.
318 It has six configurable endpoints, as well as endpoint zero
319 (for control transfers) and several endpoints with dedicated
322 PLX 3380 / 3382 is a PCIe based USB peripheral controller which
323 supports full, high speed USB 2.0 and super speed USB 3.0
326 It has eight configurable endpoints, as well as endpoint zero
327 (for control transfers) and several endpoints with dedicated
330 Say "y" to link the driver statically, or "m" to build a
331 dynamically linked module called "net2280" and force all
332 gadget drivers to also be dynamically linked.
335 tristate "Toshiba TC86C001 'Goku-S'"
338 The Toshiba TC86C001 is a PCI device which includes controllers
339 for full speed USB devices, IDE, I2C, SIO, plus a USB host (OHCI).
341 The device controller has three configurable (bulk or interrupt)
342 endpoints, plus endpoint zero (for control transfers).
344 Say "y" to link the driver statically, or "m" to build a
345 dynamically linked module called "goku_udc" and to force all
346 gadget drivers to also be dynamically linked.
349 tristate "Intel QUARK X1000/EG20T PCH/LAPIS Semiconductor IOH(ML7213/ML7831) UDC"
352 This is a USB device driver for EG20T PCH.
353 EG20T PCH is the platform controller hub that is used in Intel's
354 general embedded platform. EG20T PCH has USB device interface.
355 Using this interface, it is able to access system devices connected
357 This driver enables USB device function.
358 USB device is a USB peripheral controller which
359 supports both full and high speed USB 2.0 data transfers.
360 This driver supports both control transfer and bulk transfer modes.
361 This driver dose not support interrupt transfer or isochronous
364 This driver also can be used for LAPIS Semiconductor's ML7213 which is
365 for IVI(In-Vehicle Infotainment) use.
366 ML7831 is for general purpose use.
367 ML7213/ML7831 is companion chip for Intel Atom E6xx series.
368 ML7213/ML7831 is completely compatible for Intel EG20T PCH.
370 This driver can be used with Intel's Quark X1000 SOC platform
372 config USB_GADGET_XILINX
373 tristate "Xilinx USB Driver"
375 depends on OF || COMPILE_TEST
377 USB peripheral controller driver for Xilinx USB2 device.
378 Xilinx USB2 device is a soft IP which supports both full
379 and high speed USB 2.0 data transfers. It has seven configurable
380 endpoints(bulk or interrupt or isochronous), as well as
381 endpoint zero(for control transfers).
383 Say "y" to link the driver statically, or "m" to build a
384 dynamically linked module called "udc-xilinx" and force all
385 gadget drivers to also be dynamically linked.
388 # LAST -- dummy/emulated controller
392 tristate "Dummy HCD (DEVELOPMENT)"
393 depends on USB=y || (USB=m && USB_GADGET=m)
395 This host controller driver emulates USB, looping all data transfer
396 requests back to a USB "gadget driver" in the same host. The host
397 side is the master; the gadget side is the slave. Gadget drivers
398 can be high, full, or low speed; and they have access to endpoints
399 like those from NET2280, PXA2xx, or SA1100 hardware.
401 This may help in some stages of creating a driver to embed in a
402 Linux device, since it lets you debug several parts of the gadget
403 driver without its hardware or drivers being involved.
405 Since such a gadget side driver needs to interoperate with a host
406 side Linux-USB device driver, this may help to debug both sides
407 of a USB protocol stack.
409 Say "y" to link the driver statically, or "m" to build a
410 dynamically linked module called "dummy_hcd" and force all
411 gadget drivers to also be dynamically linked.
413 # NOTE: Please keep dummy_hcd LAST so that "real hardware" appears
414 # first and will be selected by default.