xref: /openbmc/u-boot/drivers/usb/gadget/Kconfig (revision 0649cd0d)
1#
2# USB Gadget support on a system involves
3#    (a) a peripheral controller, and
4#    (b) the gadget driver using it.
5#
6# NOTE:  Gadget support ** DOES NOT ** depend on host-side CONFIG_USB !!
7#
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.
11#
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).
14#
15
16menuconfig USB_GADGET
17	bool "USB Gadget Support"
18	help
19	   USB is a master/slave protocol, organized with one master
20	   host (such as a PC) controlling up to 127 peripheral devices.
21	   The USB hardware is asymmetric, which makes it easier to set up:
22	   you can't connect a "to-the-host" connector to a peripheral.
23
24	   U-Boot can run in the host, or in the peripheral.  In both cases
25	   you need a low level bus controller driver, and some software
26	   talking to it.  Peripheral controllers are often discrete silicon,
27	   or are integrated with the CPU in a microcontroller.  The more
28	   familiar host side controllers have names like "EHCI", "OHCI",
29	   or "UHCI", and are usually integrated into southbridges on PC
30	   motherboards.
31
32	   Enable this configuration option if you want to run U-Boot inside
33	   a USB peripheral device.  Configure one hardware driver for your
34	   peripheral/device side bus controller, and a "gadget driver" for
35	   your peripheral protocol.
36
37if USB_GADGET
38
39config USB_GADGET_ATMEL_USBA
40	bool "Atmel USBA"
41	select USB_GADGET_DUALSPEED
42	help
43	  USBA is the integrated high-speed USB Device controller on
44	  the AT32AP700x, some AT91SAM9 and AT91CAP9 processors from Atmel.
45
46config USB_GADGET_BCM_UDC_OTG_PHY
47	bool "Broadcom UDC OTG PHY"
48	help
49	  Enable the Broadcom UDC OTG physical device interface.
50
51config USB_GADGET_DWC2_OTG
52	bool "DesignWare USB2.0 HS OTG controller (gadget mode)"
53	select USB_GADGET_DUALSPEED
54	help
55	  The Designware USB2.0 high-speed gadget controller
56	  integrated into many SoCs. Select this option if you want the
57	  driver to operate in Peripheral mode. This option requires
58	  USB_GADGET to be enabled.
59
60if USB_GADGET_DWC2_OTG
61
62config USB_GADGET_DWC2_OTG_PHY_BUS_WIDTH_8
63	bool "DesignWare USB2.0 HS OTG controller 8-bit PHY bus width"
64	help
65	  Set the Designware USB2.0 high-speed OTG controller
66	  PHY interface width to 8 bits, rather than the default (16 bits).
67
68endif # USB_GADGET_DWC2_OTG
69
70config CI_UDC
71	bool "ChipIdea device controller"
72	select USB_GADGET_DUALSPEED
73	help
74	  Say Y here to enable device controller functionality of the
75	  ChipIdea driver.
76
77config USB_GADGET_VBUS_DRAW
78	int "Maximum VBUS Power usage (2-500 mA)"
79	range 2 500
80	default 2
81	help
82	   Some devices need to draw power from USB when they are
83	   configured, perhaps to operate circuitry or to recharge
84	   batteries.  This is in addition to any local power supply,
85	   such as an AC adapter or batteries.
86
87	   Enter the maximum power your device draws through USB, in
88	   milliAmperes.  The permitted range of values is 2 - 500 mA;
89	   0 mA would be legal, but can make some hosts misbehave.
90
91	   This value will be used except for system-specific gadget
92	   drivers that have more specific information.
93
94# Selected by UDC drivers that support high-speed operation.
95config USB_GADGET_DUALSPEED
96	bool
97
98config USB_GADGET_DOWNLOAD
99	bool "Enable USB download gadget"
100	help
101	  Composite USB download gadget support (g_dnl) for download functions.
102	  This code works on top of composite gadget.
103
104if USB_GADGET_DOWNLOAD
105
106config G_DNL_MANUFACTURER
107	string "Vendor name of USB device"
108
109config G_DNL_VENDOR_NUM
110	hex "Vendor ID of USB device"
111
112config G_DNL_PRODUCT_NUM
113	hex "Product ID of USB device"
114
115config USBNET_DEVADDR
116	string "USB Gadget Ethernet device mac address"
117	default "de:ad:be:ef:00:01"
118
119endif # USB_GADGET_DOWNLOAD
120
121endif # USB_GADGET
122