xref: /openbmc/linux/drivers/usb/gadget/Kconfig (revision a5beaaf3)
11da177e4SLinus Torvalds#
21da177e4SLinus Torvalds# USB Gadget support on a system involves
31da177e4SLinus Torvalds#    (a) a peripheral controller, and
41da177e4SLinus Torvalds#    (b) the gadget driver using it.
51da177e4SLinus Torvalds#
61da177e4SLinus Torvalds# NOTE:  Gadget support ** DOES NOT ** depend on host-side CONFIG_USB !!
71da177e4SLinus Torvalds#
81da177e4SLinus Torvalds#  - Host systems (like PCs) need CONFIG_USB (with "A" jacks).
91da177e4SLinus Torvalds#  - Peripherals (like PDAs) need CONFIG_USB_GADGET (with "B" jacks).
10cab00891SMatt LaPlante#  - Some systems have both kinds of controllers.
111da177e4SLinus Torvalds#
121da177e4SLinus Torvalds# With help from a special transceiver and a "Mini-AB" jack, systems with
131da177e4SLinus Torvalds# both kinds of controller can also support "USB On-the-Go" (CONFIG_USB_OTG).
141da177e4SLinus Torvalds#
151da177e4SLinus Torvalds
16b75be4abSDenis Chengmenuconfig USB_GADGET
17b75be4abSDenis Cheng	tristate "USB Gadget Support"
1886dc243cSAlan Stern	select NLS
191da177e4SLinus Torvalds	help
201da177e4SLinus Torvalds	   USB is a master/slave protocol, organized with one master
211da177e4SLinus Torvalds	   host (such as a PC) controlling up to 127 peripheral devices.
221da177e4SLinus Torvalds	   The USB hardware is asymmetric, which makes it easier to set up:
231da177e4SLinus Torvalds	   you can't connect a "to-the-host" connector to a peripheral.
241da177e4SLinus Torvalds
251da177e4SLinus Torvalds	   Linux can run in the host, or in the peripheral.  In both cases
261da177e4SLinus Torvalds	   you need a low level bus controller driver, and some software
271da177e4SLinus Torvalds	   talking to it.  Peripheral controllers are often discrete silicon,
281da177e4SLinus Torvalds	   or are integrated with the CPU in a microcontroller.  The more
29e113f29cSJules Villard	   familiar host side controllers have names like "EHCI", "OHCI",
301da177e4SLinus Torvalds	   or "UHCI", and are usually integrated into southbridges on PC
311da177e4SLinus Torvalds	   motherboards.
321da177e4SLinus Torvalds
331da177e4SLinus Torvalds	   Enable this configuration option if you want to run Linux inside
341da177e4SLinus Torvalds	   a USB peripheral device.  Configure one hardware driver for your
351da177e4SLinus Torvalds	   peripheral/device side bus controller, and a "gadget driver" for
361da177e4SLinus Torvalds	   your peripheral protocol.  (If you use modular gadget drivers,
371da177e4SLinus Torvalds	   you may configure more than one.)
381da177e4SLinus Torvalds
391da177e4SLinus Torvalds	   If in doubt, say "N" and don't enable these drivers; most people
401da177e4SLinus Torvalds	   don't have this kind of hardware (except maybe inside Linux PDAs).
411da177e4SLinus Torvalds
421da177e4SLinus Torvalds	   For more information, see <http://www.linux-usb.org/gadget> and
431da177e4SLinus Torvalds	   the kernel DocBook documentation for this API.
441da177e4SLinus Torvalds
45b75be4abSDenis Chengif USB_GADGET
46b75be4abSDenis Cheng
4770790f63SDavid Brownellconfig USB_GADGET_DEBUG
486341e62bSChristoph Jaeger	bool "Debugging messages (DEVELOPMENT)"
4936e893d2SDavid Brownell	depends on DEBUG_KERNEL
5070790f63SDavid Brownell	help
5170790f63SDavid Brownell	   Many controller and gadget drivers will print some debugging
5270790f63SDavid Brownell	   messages if you use this option to ask for those messages.
5370790f63SDavid Brownell
5470790f63SDavid Brownell	   Avoid enabling these messages, even if you're actively
5570790f63SDavid Brownell	   debugging such a driver.  Many drivers will emit so many
5670790f63SDavid Brownell	   messages that the driver timings are affected, which will
5770790f63SDavid Brownell	   either create new failure modes or remove the one you're
5870790f63SDavid Brownell	   trying to track down.  Never enable these messages for a
5970790f63SDavid Brownell	   production build.
6070790f63SDavid Brownell
61cd108691SAndreas Larssonconfig USB_GADGET_VERBOSE
62cd108691SAndreas Larsson	bool "Verbose debugging Messages (DEVELOPMENT)"
63cd108691SAndreas Larsson	depends on USB_GADGET_DEBUG
64cd108691SAndreas Larsson	help
65cd108691SAndreas Larsson	   Many controller and gadget drivers will print verbose debugging
66cd108691SAndreas Larsson	   messages if you use this option to ask for those messages.
67cd108691SAndreas Larsson
68cd108691SAndreas Larsson	   Avoid enabling these messages, even if you're actively
69cd108691SAndreas Larsson	   debugging such a driver.  Many drivers will emit so many
70cd108691SAndreas Larsson	   messages that the driver timings are affected, which will
71cd108691SAndreas Larsson	   either create new failure modes or remove the one you're
72cd108691SAndreas Larsson	   trying to track down.  Never enable these messages for a
73cd108691SAndreas Larsson	   production build.
74cd108691SAndreas Larsson
751da177e4SLinus Torvaldsconfig USB_GADGET_DEBUG_FILES
766341e62bSChristoph Jaeger	bool "Debugging information files (DEVELOPMENT)"
7736e893d2SDavid Brownell	depends on PROC_FS
781da177e4SLinus Torvalds	help
791da177e4SLinus Torvalds	   Some of the drivers in the "gadget" framework can expose
801da177e4SLinus Torvalds	   debugging information in files such as /proc/driver/udc
811da177e4SLinus Torvalds	   (for a peripheral controller).  The information in these
821da177e4SLinus Torvalds	   files may help when you're troubleshooting or bringing up a
831da177e4SLinus Torvalds	   driver on a new board.   Enable these files by choosing "Y"
841da177e4SLinus Torvalds	   here.  If in doubt, or to conserve kernel memory, say "N".
851da177e4SLinus Torvalds
86914a3f3bSHaavard Skinnemoenconfig USB_GADGET_DEBUG_FS
876341e62bSChristoph Jaeger	bool "Debugging information files in debugfs (DEVELOPMENT)"
8836e893d2SDavid Brownell	depends on DEBUG_FS
89914a3f3bSHaavard Skinnemoen	help
90914a3f3bSHaavard Skinnemoen	   Some of the drivers in the "gadget" framework can expose
91914a3f3bSHaavard Skinnemoen	   debugging information in files under /sys/kernel/debug/.
92914a3f3bSHaavard Skinnemoen	   The information in these files may help when you're
93914a3f3bSHaavard Skinnemoen	   troubleshooting or bringing up a driver on a new board.
94914a3f3bSHaavard Skinnemoen	   Enable these files by choosing "Y" here.  If in doubt, or
95914a3f3bSHaavard Skinnemoen	   to conserve kernel memory, say "N".
96914a3f3bSHaavard Skinnemoen
9736e893d2SDavid Brownellconfig USB_GADGET_VBUS_DRAW
9836e893d2SDavid Brownell	int "Maximum VBUS Power usage (2-500 mA)"
9936e893d2SDavid Brownell	range 2 500
10036e893d2SDavid Brownell	default 2
10136e893d2SDavid Brownell	help
10236e893d2SDavid Brownell	   Some devices need to draw power from USB when they are
10336e893d2SDavid Brownell	   configured, perhaps to operate circuitry or to recharge
10436e893d2SDavid Brownell	   batteries.  This is in addition to any local power supply,
10536e893d2SDavid Brownell	   such as an AC adapter or batteries.
10636e893d2SDavid Brownell
10736e893d2SDavid Brownell	   Enter the maximum power your device draws through USB, in
10836e893d2SDavid Brownell	   milliAmperes.  The permitted range of values is 2 - 500 mA;
10936e893d2SDavid Brownell	   0 mA would be legal, but can make some hosts misbehave.
11036e893d2SDavid Brownell
11136e893d2SDavid Brownell	   This value will be used except for system-specific gadget
11236e893d2SDavid Brownell	   drivers that have more specific information.
11336e893d2SDavid Brownell
1146532c7fdSPer Forlinconfig USB_GADGET_STORAGE_NUM_BUFFERS
1156532c7fdSPer Forlin	int "Number of storage pipeline buffers"
1162e6c72b6SFelipe Balbi	range 2 32
1176532c7fdSPer Forlin	default 2
1186532c7fdSPer Forlin	help
1196532c7fdSPer Forlin	   Usually 2 buffers are enough to establish a good buffering
1206532c7fdSPer Forlin	   pipeline. The number may be increased in order to compensate
1216532c7fdSPer Forlin	   for a bursty VFS behaviour. For instance there may be CPU wake up
1226532c7fdSPer Forlin	   latencies that makes the VFS to appear bursty in a system with
1236532c7fdSPer Forlin	   an CPU on-demand governor. Especially if DMA is doing IO to
1246532c7fdSPer Forlin	   offload the CPU. In this case the CPU will go into power
1256532c7fdSPer Forlin	   save often and spin up occasionally to move data within VFS.
1266532c7fdSPer Forlin	   If selecting USB_GADGET_DEBUG_FILES this value may be set by
1276532c7fdSPer Forlin	   a module parameter as well.
1286532c7fdSPer Forlin	   If unsure, say 2.
1296532c7fdSPer Forlin
130a5beaaf3SBaolin Wangconfig U_SERIAL_CONSOLE
131a5beaaf3SBaolin Wang	bool "Serial gadget console support"
132a5beaaf3SBaolin Wang	depends on USB_G_SERIAL
133a5beaaf3SBaolin Wang	help
134a5beaaf3SBaolin Wang	   It supports the serial gadget can be used as a console.
135a5beaaf3SBaolin Wang
13690fccb52SAndrzej Pietrasiewiczsource "drivers/usb/gadget/udc/Kconfig"
1371da177e4SLinus Torvalds
1381da177e4SLinus Torvalds#
1391da177e4SLinus Torvalds# USB Gadget Drivers
1401da177e4SLinus Torvalds#
141a84d9e53SSebastian Andrzej Siewior
142a84d9e53SSebastian Andrzej Siewior# composite based drivers
143a84d9e53SSebastian Andrzej Siewiorconfig USB_LIBCOMPOSITE
144a84d9e53SSebastian Andrzej Siewior	tristate
14588af8bbeSSebastian Andrzej Siewior	select CONFIGFS_FS
146a84d9e53SSebastian Andrzej Siewior	depends on USB_GADGET
147a84d9e53SSebastian Andrzej Siewior
148ff47f594SSebastian Andrzej Siewiorconfig USB_F_ACM
149ff47f594SSebastian Andrzej Siewior	tristate
150ff47f594SSebastian Andrzej Siewior
151cf9a08aeSSebastian Andrzej Siewiorconfig USB_F_SS_LB
152cf9a08aeSSebastian Andrzej Siewior	tristate
153cf9a08aeSSebastian Andrzej Siewior
1543249ca22SSebastian Andrzej Siewiorconfig USB_U_SERIAL
1553249ca22SSebastian Andrzej Siewior	tristate
1563249ca22SSebastian Andrzej Siewior
157f1a1823fSAndrzej Pietrasiewiczconfig USB_U_ETHER
158f1a1823fSAndrzej Pietrasiewicz	tristate
159f1a1823fSAndrzej Pietrasiewicz
16060540ea2SAndrzej Pietrasiewiczconfig USB_F_SERIAL
16160540ea2SAndrzej Pietrasiewicz	tristate
16260540ea2SAndrzej Pietrasiewicz
1631d8fc251SAndrzej Pietrasiewiczconfig USB_F_OBEX
1641d8fc251SAndrzej Pietrasiewicz	tristate
1651d8fc251SAndrzej Pietrasiewicz
16640d133d7SAndrzej Pietrasiewiczconfig USB_F_NCM
16740d133d7SAndrzej Pietrasiewicz	tristate
16840d133d7SAndrzej Pietrasiewicz
169fee562a6SAndrzej Pietrasiewiczconfig USB_F_ECM
170fee562a6SAndrzej Pietrasiewicz	tristate
171fee562a6SAndrzej Pietrasiewicz
172fcbdf12eSAndrzej Pietrasiewiczconfig USB_F_PHONET
173fcbdf12eSAndrzej Pietrasiewicz	tristate
174fcbdf12eSAndrzej Pietrasiewicz
175b29002a1SAndrzej Pietrasiewiczconfig USB_F_EEM
176b29002a1SAndrzej Pietrasiewicz	tristate
177b29002a1SAndrzej Pietrasiewicz
1788cedba7cSAndrzej Pietrasiewiczconfig USB_F_SUBSET
1798cedba7cSAndrzej Pietrasiewicz	tristate
1808cedba7cSAndrzej Pietrasiewicz
181f466c635SAndrzej Pietrasiewiczconfig USB_F_RNDIS
182f466c635SAndrzej Pietrasiewicz	tristate
183f466c635SAndrzej Pietrasiewicz
184e5eaa0dcSAndrzej Pietrasiewiczconfig USB_F_MASS_STORAGE
185e5eaa0dcSAndrzej Pietrasiewicz	tristate
186e5eaa0dcSAndrzej Pietrasiewicz
1875920cda6SAndrzej Pietrasiewiczconfig USB_F_FS
1885920cda6SAndrzej Pietrasiewicz	tristate
1895920cda6SAndrzej Pietrasiewicz
190f3a3406bSAndrzej Pietrasiewiczconfig USB_F_UAC1
191f3a3406bSAndrzej Pietrasiewicz	tristate
192f3a3406bSAndrzej Pietrasiewicz
193f8f93d24SAndrzej Pietrasiewiczconfig USB_F_UAC2
194f8f93d24SAndrzej Pietrasiewicz	tristate
195f8f93d24SAndrzej Pietrasiewicz
1966d11ed76SAndrzej Pietrasiewiczconfig USB_F_UVC
1976d11ed76SAndrzej Pietrasiewicz	tristate
1986d11ed76SAndrzej Pietrasiewicz
199b85e9de9SAndrzej Pietrasiewiczconfig USB_F_MIDI
200b85e9de9SAndrzej Pietrasiewicz	tristate
201b85e9de9SAndrzej Pietrasiewicz
202cb382536SAndrzej Pietrasiewiczconfig USB_F_HID
203cb382536SAndrzej Pietrasiewicz	tristate
204cb382536SAndrzej Pietrasiewicz
205b26394bdSAndrzej Pietrasiewiczconfig USB_F_PRINTER
206b26394bdSAndrzej Pietrasiewicz	tristate
207b26394bdSAndrzej Pietrasiewicz
2081da177e4SLinus Torvaldschoice
2091da177e4SLinus Torvalds	tristate "USB Gadget Drivers"
2101da177e4SLinus Torvalds	default USB_ETH
2111da177e4SLinus Torvalds	help
2121da177e4SLinus Torvalds	  A Linux "Gadget Driver" talks to the USB Peripheral Controller
2131da177e4SLinus Torvalds	  driver through the abstract "gadget" API.  Some other operating
2141da177e4SLinus Torvalds	  systems call these "client" drivers, of which "class drivers"
2151da177e4SLinus Torvalds	  are a subset (implementing a USB device class specification).
2161da177e4SLinus Torvalds	  A gadget driver implements one or more USB functions using
2171da177e4SLinus Torvalds	  the peripheral hardware.
2181da177e4SLinus Torvalds
2191da177e4SLinus Torvalds	  Gadget drivers are hardware-neutral, or "platform independent",
2201da177e4SLinus Torvalds	  except that they sometimes must understand quirks or limitations
2211da177e4SLinus Torvalds	  of the particular controllers they work with.  For example, when
2221da177e4SLinus Torvalds	  a controller doesn't support alternate configurations or provide
2231da177e4SLinus Torvalds	  enough of the right types of endpoints, the gadget driver might
2241da177e4SLinus Torvalds	  not be able work with that controller, or might need to implement
2251da177e4SLinus Torvalds	  a less common variant of a device class protocol.
2261da177e4SLinus Torvalds
2271da177e4SLinus Torvalds# this first set of drivers all depend on bulk-capable hardware.
2281da177e4SLinus Torvalds
229d1c02452SAndrzej Pietrasiewiczconfig USB_CONFIGFS
230d1c02452SAndrzej Pietrasiewicz	tristate "USB functions configurable through configfs"
231d1c02452SAndrzej Pietrasiewicz	select USB_LIBCOMPOSITE
232d1c02452SAndrzej Pietrasiewicz	help
233d1c02452SAndrzej Pietrasiewicz	  A Linux USB "gadget" can be set up through configfs.
234d1c02452SAndrzej Pietrasiewicz	  If this is the case, the USB functions (which from the host's
235d1c02452SAndrzej Pietrasiewicz	  perspective are seen as interfaces) and configurations are
236d1c02452SAndrzej Pietrasiewicz	  specified simply by creating appropriate directories in configfs.
237d1c02452SAndrzej Pietrasiewicz	  Associating functions with configurations is done by creating
238d1c02452SAndrzej Pietrasiewicz	  appropriate symbolic links.
2399c1d6962SPhilippe De Swert	  For more information see Documentation/usb/gadget_configfs.txt.
240d1c02452SAndrzej Pietrasiewicz
241d1c02452SAndrzej Pietrasiewiczconfig USB_CONFIGFS_SERIAL
2426341e62bSChristoph Jaeger	bool "Generic serial bulk in/out"
243d1c02452SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
244d1c02452SAndrzej Pietrasiewicz	depends on TTY
245d1c02452SAndrzej Pietrasiewicz	select USB_U_SERIAL
246d1c02452SAndrzej Pietrasiewicz	select USB_F_SERIAL
247d1c02452SAndrzej Pietrasiewicz	help
248d1c02452SAndrzej Pietrasiewicz	  The function talks to the Linux-USB generic serial driver.
249d1c02452SAndrzej Pietrasiewicz
250d1c02452SAndrzej Pietrasiewiczconfig USB_CONFIGFS_ACM
2516341e62bSChristoph Jaeger	bool "Abstract Control Model (CDC ACM)"
252d1c02452SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
253d1c02452SAndrzej Pietrasiewicz	depends on TTY
254d1c02452SAndrzej Pietrasiewicz	select USB_U_SERIAL
255d1c02452SAndrzej Pietrasiewicz	select USB_F_ACM
256d1c02452SAndrzej Pietrasiewicz	help
257d1c02452SAndrzej Pietrasiewicz	  ACM serial link.  This function can be used to interoperate with
258d1c02452SAndrzej Pietrasiewicz	  MS-Windows hosts or with the Linux-USB "cdc-acm" driver.
259d1c02452SAndrzej Pietrasiewicz
260d1c02452SAndrzej Pietrasiewiczconfig USB_CONFIGFS_OBEX
2616341e62bSChristoph Jaeger	bool "Object Exchange Model (CDC OBEX)"
262d1c02452SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
263d1c02452SAndrzej Pietrasiewicz	depends on TTY
264d1c02452SAndrzej Pietrasiewicz	select USB_U_SERIAL
265d1c02452SAndrzej Pietrasiewicz	select USB_F_OBEX
266d1c02452SAndrzej Pietrasiewicz	help
267d1c02452SAndrzej Pietrasiewicz	  You will need a user space OBEX server talking to /dev/ttyGS*,
268d1c02452SAndrzej Pietrasiewicz	  since the kernel itself doesn't implement the OBEX protocol.
269d1c02452SAndrzej Pietrasiewicz
270d1c02452SAndrzej Pietrasiewiczconfig USB_CONFIGFS_NCM
2716341e62bSChristoph Jaeger	bool "Network Control Model (CDC NCM)"
272d1c02452SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
273d1c02452SAndrzej Pietrasiewicz	depends on NET
274d1c02452SAndrzej Pietrasiewicz	select USB_U_ETHER
275d1c02452SAndrzej Pietrasiewicz	select USB_F_NCM
276d1c02452SAndrzej Pietrasiewicz	help
277d1c02452SAndrzej Pietrasiewicz	  NCM is an advanced protocol for Ethernet encapsulation, allows
278d1c02452SAndrzej Pietrasiewicz	  grouping of several ethernet frames into one USB transfer and
279d1c02452SAndrzej Pietrasiewicz	  different alignment possibilities.
280d1c02452SAndrzej Pietrasiewicz
281d1c02452SAndrzej Pietrasiewiczconfig USB_CONFIGFS_ECM
2826341e62bSChristoph Jaeger	bool "Ethernet Control Model (CDC ECM)"
283d1c02452SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
284d1c02452SAndrzej Pietrasiewicz	depends on NET
285d1c02452SAndrzej Pietrasiewicz	select USB_U_ETHER
286d1c02452SAndrzej Pietrasiewicz	select USB_F_ECM
287d1c02452SAndrzej Pietrasiewicz	help
288d1c02452SAndrzej Pietrasiewicz	  The "Communication Device Class" (CDC) Ethernet Control Model.
289d1c02452SAndrzej Pietrasiewicz	  That protocol is often avoided with pure Ethernet adapters, in
290d1c02452SAndrzej Pietrasiewicz	  favor of simpler vendor-specific hardware, but is widely
291d1c02452SAndrzej Pietrasiewicz	  supported by firmware for smart network devices.
292d1c02452SAndrzej Pietrasiewicz
29302832e56SAndrzej Pietrasiewiczconfig USB_CONFIGFS_ECM_SUBSET
2946341e62bSChristoph Jaeger	bool "Ethernet Control Model (CDC ECM) subset"
29502832e56SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
29602832e56SAndrzej Pietrasiewicz	depends on NET
29702832e56SAndrzej Pietrasiewicz	select USB_U_ETHER
29802832e56SAndrzej Pietrasiewicz	select USB_F_SUBSET
29902832e56SAndrzej Pietrasiewicz	help
30002832e56SAndrzej Pietrasiewicz	  On hardware that can't implement the full protocol,
30102832e56SAndrzej Pietrasiewicz	  a simple CDC subset is used, placing fewer demands on USB.
30202832e56SAndrzej Pietrasiewicz
303b3df2faaSAndrzej Pietrasiewiczconfig USB_CONFIGFS_RNDIS
304b3df2faaSAndrzej Pietrasiewicz	bool "RNDIS"
305b3df2faaSAndrzej Pietrasiewicz	depends on USB_CONFIGFS
306b3df2faaSAndrzej Pietrasiewicz	depends on NET
307b3df2faaSAndrzej Pietrasiewicz	select USB_U_ETHER
308b3df2faaSAndrzej Pietrasiewicz	select USB_F_RNDIS
309b3df2faaSAndrzej Pietrasiewicz	help
310b3df2faaSAndrzej Pietrasiewicz	   Microsoft Windows XP bundles the "Remote NDIS" (RNDIS) protocol,
311b3df2faaSAndrzej Pietrasiewicz	   and Microsoft provides redistributable binary RNDIS drivers for
312b3df2faaSAndrzej Pietrasiewicz	   older versions of Windows.
313b3df2faaSAndrzej Pietrasiewicz
314b3df2faaSAndrzej Pietrasiewicz	   To make MS-Windows work with this, use Documentation/usb/linux.inf
315b3df2faaSAndrzej Pietrasiewicz	   as the "driver info file".  For versions of MS-Windows older than
316b3df2faaSAndrzej Pietrasiewicz	   XP, you'll need to download drivers from Microsoft's website; a URL
317b3df2faaSAndrzej Pietrasiewicz	   is given in comments found in that info file.
318b3df2faaSAndrzej Pietrasiewicz
31917b80976SAndrzej Pietrasiewiczconfig USB_CONFIGFS_EEM
32017b80976SAndrzej Pietrasiewicz	bool "Ethernet Emulation Model (EEM)"
32117b80976SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
32217b80976SAndrzej Pietrasiewicz	depends on NET
32317b80976SAndrzej Pietrasiewicz	select USB_U_ETHER
32417b80976SAndrzej Pietrasiewicz	select USB_F_EEM
32517b80976SAndrzej Pietrasiewicz	help
32617b80976SAndrzej Pietrasiewicz	  CDC EEM is a newer USB standard that is somewhat simpler than CDC ECM
32717b80976SAndrzej Pietrasiewicz	  and therefore can be supported by more hardware.  Technically ECM and
32817b80976SAndrzej Pietrasiewicz	  EEM are designed for different applications.  The ECM model extends
32917b80976SAndrzej Pietrasiewicz	  the network interface to the target (e.g. a USB cable modem), and the
33017b80976SAndrzej Pietrasiewicz	  EEM model is for mobile devices to communicate with hosts using
33117b80976SAndrzej Pietrasiewicz	  ethernet over USB.  For Linux gadgets, however, the interface with
33217b80976SAndrzej Pietrasiewicz	  the host is the same (a usbX device), so the differences are minimal.
33317b80976SAndrzej Pietrasiewicz
33483408745SAndrzej Pietrasiewiczconfig USB_CONFIGFS_PHONET
3356341e62bSChristoph Jaeger	bool "Phonet protocol"
33683408745SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
33783408745SAndrzej Pietrasiewicz	depends on NET
33883408745SAndrzej Pietrasiewicz	depends on PHONET
33983408745SAndrzej Pietrasiewicz	select USB_U_ETHER
34083408745SAndrzej Pietrasiewicz	select USB_F_PHONET
34183408745SAndrzej Pietrasiewicz	help
34283408745SAndrzej Pietrasiewicz	  The Phonet protocol implementation for USB device.
34383408745SAndrzej Pietrasiewicz
344ef0aa4b9SAndrzej Pietrasiewiczconfig USB_CONFIGFS_MASS_STORAGE
3456341e62bSChristoph Jaeger	bool "Mass storage"
346ef0aa4b9SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
347bc912b0dSAndrzej Pietrasiewicz	depends on BLOCK
348ef0aa4b9SAndrzej Pietrasiewicz	select USB_F_MASS_STORAGE
349ef0aa4b9SAndrzej Pietrasiewicz	help
350ef0aa4b9SAndrzej Pietrasiewicz	  The Mass Storage Gadget acts as a USB Mass Storage disk drive.
351ef0aa4b9SAndrzej Pietrasiewicz	  As its storage repository it can use a regular file or a block
352ef0aa4b9SAndrzej Pietrasiewicz	  device (in much the same way as the "loop" device driver),
353ef0aa4b9SAndrzej Pietrasiewicz	  specified as a module parameter or sysfs option.
354ef0aa4b9SAndrzej Pietrasiewicz
35525d80151SAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_LB_SS
3566341e62bSChristoph Jaeger	bool "Loopback and sourcesink function (for testing)"
357c0501f47SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
358c0501f47SAndrzej Pietrasiewicz	select USB_F_SS_LB
359c0501f47SAndrzej Pietrasiewicz	help
36025d80151SAndrzej Pietrasiewicz	  Loopback function loops back a configurable number of transfers.
36125d80151SAndrzej Pietrasiewicz	  Sourcesink function either sinks and sources bulk data.
362c0501f47SAndrzej Pietrasiewicz	  It also implements control requests, for "chapter 9" conformance.
363c0501f47SAndrzej Pietrasiewicz	  Make this be the first driver you try using on top of any new
364c0501f47SAndrzej Pietrasiewicz	  USB peripheral controller driver.  Then you can use host-side
365c0501f47SAndrzej Pietrasiewicz	  test software, like the "usbtest" driver, to put your hardware
366c0501f47SAndrzej Pietrasiewicz	  and its driver through a basic set of functional tests.
367c0501f47SAndrzej Pietrasiewicz
368b658499fSAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_FS
3696341e62bSChristoph Jaeger	bool "Function filesystem (FunctionFS)"
370b658499fSAndrzej Pietrasiewicz	depends on USB_CONFIGFS
371b658499fSAndrzej Pietrasiewicz	select USB_F_FS
372b658499fSAndrzej Pietrasiewicz	help
373b658499fSAndrzej Pietrasiewicz	  The Function Filesystem (FunctionFS) lets one create USB
374b658499fSAndrzej Pietrasiewicz	  composite functions in user space in the same way GadgetFS
375b658499fSAndrzej Pietrasiewicz	  lets one create USB gadgets in user space.  This allows creation
376b658499fSAndrzej Pietrasiewicz	  of composite gadgets such that some of the functions are
377b658499fSAndrzej Pietrasiewicz	  implemented in kernel space (for instance Ethernet, serial or
378b658499fSAndrzej Pietrasiewicz	  mass storage) and other are implemented in user space.
379b658499fSAndrzej Pietrasiewicz
380cb0a59f5SAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_UAC1
3816341e62bSChristoph Jaeger	bool "Audio Class 1.0"
382cb0a59f5SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
383cb0a59f5SAndrzej Pietrasiewicz	depends on SND
384cb0a59f5SAndrzej Pietrasiewicz	select USB_LIBCOMPOSITE
385cb0a59f5SAndrzej Pietrasiewicz	select SND_PCM
386cb0a59f5SAndrzej Pietrasiewicz	select USB_F_UAC1
387cb0a59f5SAndrzej Pietrasiewicz	help
388cb0a59f5SAndrzej Pietrasiewicz	  This Audio function implements 1 AudioControl interface,
389cb0a59f5SAndrzej Pietrasiewicz	  1 AudioStreaming Interface each for USB-OUT and USB-IN.
390cb0a59f5SAndrzej Pietrasiewicz	  This driver requires a real Audio codec to be present
391cb0a59f5SAndrzej Pietrasiewicz	  on the device.
392cb0a59f5SAndrzej Pietrasiewicz
393cb0a59f5SAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_UAC2
3946341e62bSChristoph Jaeger	bool "Audio Class 2.0"
395cb0a59f5SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
396cb0a59f5SAndrzej Pietrasiewicz	depends on SND
397cb0a59f5SAndrzej Pietrasiewicz	select USB_LIBCOMPOSITE
398cb0a59f5SAndrzej Pietrasiewicz	select SND_PCM
399cb0a59f5SAndrzej Pietrasiewicz	select USB_F_UAC2
400cb0a59f5SAndrzej Pietrasiewicz	help
401cb0a59f5SAndrzej Pietrasiewicz	  This Audio function is compatible with USB Audio Class
402cb0a59f5SAndrzej Pietrasiewicz	  specification 2.0. It implements 1 AudioControl interface,
403cb0a59f5SAndrzej Pietrasiewicz	  1 AudioStreaming Interface each for USB-OUT and USB-IN.
404cb0a59f5SAndrzej Pietrasiewicz	  This driver doesn't expect any real Audio codec to be present
405cb0a59f5SAndrzej Pietrasiewicz	  on the device - the audio streams are simply sinked to and
406cb0a59f5SAndrzej Pietrasiewicz	  sourced from a virtual ALSA sound card created. The user-space
407cb0a59f5SAndrzej Pietrasiewicz	  application may choose to do whatever it wants with the data
408cb0a59f5SAndrzej Pietrasiewicz	  received from the USB Host and choose to provide whatever it
409cb0a59f5SAndrzej Pietrasiewicz	  wants as audio data to the USB Host.
410cb0a59f5SAndrzej Pietrasiewicz
4116f1de344SAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_MIDI
4126341e62bSChristoph Jaeger	bool "MIDI function"
4136f1de344SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
4146f1de344SAndrzej Pietrasiewicz	depends on SND
4156f1de344SAndrzej Pietrasiewicz	select USB_LIBCOMPOSITE
4166f1de344SAndrzej Pietrasiewicz	select SND_RAWMIDI
4176f1de344SAndrzej Pietrasiewicz	select USB_F_MIDI
4186f1de344SAndrzej Pietrasiewicz	help
4196f1de344SAndrzej Pietrasiewicz	  The MIDI Function acts as a USB Audio device, with one MIDI
4206f1de344SAndrzej Pietrasiewicz	  input and one MIDI output. These MIDI jacks appear as
4216f1de344SAndrzej Pietrasiewicz	  a sound "card" in the ALSA sound system. Other MIDI
4226f1de344SAndrzej Pietrasiewicz	  connections can then be made on the gadget system, using
4236f1de344SAndrzej Pietrasiewicz	  ALSA's aconnect utility etc.
4246f1de344SAndrzej Pietrasiewicz
42521a9476aSAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_HID
4266341e62bSChristoph Jaeger	bool "HID function"
42721a9476aSAndrzej Pietrasiewicz	depends on USB_CONFIGFS
42821a9476aSAndrzej Pietrasiewicz	select USB_F_HID
42921a9476aSAndrzej Pietrasiewicz	help
43021a9476aSAndrzej Pietrasiewicz	  The HID function driver provides generic emulation of USB
43121a9476aSAndrzej Pietrasiewicz	  Human Interface Devices (HID).
43221a9476aSAndrzej Pietrasiewicz
43321a9476aSAndrzej Pietrasiewicz	  For more information, see Documentation/usb/gadget_hid.txt.
43421a9476aSAndrzej Pietrasiewicz
43546919a23SAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_UVC
4368333d3cdSChristoph Jaeger	bool "USB Webcam function"
43746919a23SAndrzej Pietrasiewicz	depends on USB_CONFIGFS
43846919a23SAndrzej Pietrasiewicz	depends on VIDEO_DEV
43946919a23SAndrzej Pietrasiewicz	select VIDEOBUF2_VMALLOC
44046919a23SAndrzej Pietrasiewicz	select USB_F_UVC
44146919a23SAndrzej Pietrasiewicz	help
44246919a23SAndrzej Pietrasiewicz	  The Webcam function acts as a composite USB Audio and Video Class
44346919a23SAndrzej Pietrasiewicz	  device. It provides a userspace API to process UVC control requests
44446919a23SAndrzej Pietrasiewicz	  and stream video data to the host.
44546919a23SAndrzej Pietrasiewicz
446ee1cd515SAndrzej Pietrasiewiczconfig USB_CONFIGFS_F_PRINTER
447ee1cd515SAndrzej Pietrasiewicz	bool "Printer function"
448ee1cd515SAndrzej Pietrasiewicz	select USB_F_PRINTER
449f4b4976bSAndrzej Pietrasiewicz	depends on USB_CONFIGFS
450ee1cd515SAndrzej Pietrasiewicz	help
451ee1cd515SAndrzej Pietrasiewicz	  The Printer function channels data between the USB host and a
452ee1cd515SAndrzej Pietrasiewicz	  userspace program driving the print engine. The user space
453ee1cd515SAndrzej Pietrasiewicz	  program reads and writes the device file /dev/g_printer<X> to
454ee1cd515SAndrzej Pietrasiewicz	  receive or send printer data. It can use ioctl calls to
455ee1cd515SAndrzej Pietrasiewicz	  the device file to get or set printer status.
456ee1cd515SAndrzej Pietrasiewicz
457ee1cd515SAndrzej Pietrasiewicz	  For more information, see Documentation/usb/gadget_printer.txt
458ee1cd515SAndrzej Pietrasiewicz	  which includes sample code for accessing the device file.
459ee1cd515SAndrzej Pietrasiewicz
4608443f2d2SAndrzej Pietrasiewiczsource "drivers/usb/gadget/legacy/Kconfig"
4611da177e4SLinus Torvalds
4621da177e4SLinus Torvaldsendchoice
4631da177e4SLinus Torvalds
464b75be4abSDenis Chengendif # USB_GADGET
465