[PATCH] USB: only make /sys/class/usb show up when there is something in it
[linux-2.6] / drivers / usb / input / Kconfig
1 #
2 # USB Input driver configuration
3 #
4 comment "USB Input Devices"
5         depends on USB
6
7 config USB_HID
8         tristate "USB Human Interface Device (full HID) support"
9         depends on USB
10         ---help---
11           Say Y here if you want full HID support to connect keyboards,
12           mice, joysticks, graphic tablets, or any other HID based devices
13           to your computer via USB. You also need to select HID Input layer
14           support (below) if you want to use keyboards, mice, joysticks and
15           the like ... as well as Uninterruptible Power Supply (UPS) and
16           monitor control devices.
17
18           You can't use this driver and the HIDBP (Boot Protocol) keyboard
19           and mouse drivers at the same time. More information is available:
20           <file:Documentation/input/input.txt>.
21
22           If unsure, say Y.
23
24           To compile this driver as a module, choose M here: the
25           module will be called usbhid.
26
27 comment "Input core support is needed for USB HID input layer or HIDBP support"
28         depends on USB_HID && INPUT=n
29
30 config USB_HIDINPUT
31         bool "HID input layer support"
32         default y
33         depends on INPUT && USB_HID
34         help
35           Say Y here if you want to use a USB keyboard, mouse or joystick,
36           or any other HID input device.
37
38           If unsure, say Y.
39
40 config USB_HIDINPUT_POWERBOOK
41         bool "Enable support for iBook/PowerBook special keys"
42         default n
43         depends on USB_HIDINPUT
44         help
45           Say Y here if you want support for the special keys (Fn, Numlock) on
46           Apple iBooks and PowerBooks.
47
48           If unsure, say N.
49
50 config HID_FF
51         bool "Force feedback support (EXPERIMENTAL)"
52         depends on USB_HIDINPUT && EXPERIMENTAL
53         help
54           Say Y here is you want force feedback support for a few HID devices.
55           See below for a list of supported devices.
56
57           See <file:Documentation/input/ff.txt> for a description of the force
58           feedback API.
59
60           If unsure, say N.
61
62 config HID_PID
63         bool "PID Devices (Microsoft Sidewinder Force Feedback 2)"
64         depends on HID_FF
65         help
66           Say Y here if you have a PID-compliant joystick and wish to enable force
67           feedback for it. The Microsoft Sidewinder Force Feedback 2 is one such
68           device.
69
70 config LOGITECH_FF
71         bool "Logitech WingMan *3D support"
72         depends on HID_FF
73         help
74           Say Y here if you have one of these devices:
75           - Logitech WingMan Cordless RumblePad
76           - Logitech WingMan Force 3D
77           and if you want to enable force feedback for them.
78           Note: if you say N here, this device will still be supported, but without
79           force feedback.
80
81 config THRUSTMASTER_FF
82         bool "ThrustMaster FireStorm Dual Power 2 support (EXPERIMENTAL)"
83         depends on HID_FF && EXPERIMENTAL
84         help
85           Say Y here if you have a THRUSTMASTER FireStore Dual Power 2,
86           and want to enable force feedback support for it.
87           Note: if you say N here, this device will still be supported, but without
88           force feedback.
89
90 config USB_HIDDEV
91         bool "/dev/hiddev raw HID device support"
92         depends on USB_HID
93         help
94           Say Y here if you want to support HID devices (from the USB
95           specification standpoint) that aren't strictly user interface
96           devices, like monitor controls and Uninterruptable Power Supplies.
97
98           This module supports these devices separately using a separate
99           event interface on /dev/usb/hiddevX (char 180:96 to 180:111).
100
101           If unsure, say Y.
102
103 menu "USB HID Boot Protocol drivers"
104         depends on USB!=n && USB_HID!=y
105
106 config USB_KBD
107         tristate "USB HIDBP Keyboard (simple Boot) support"
108         depends on USB && INPUT
109         ---help---
110           Say Y here only if you are absolutely sure that you don't want
111           to use the generic HID driver for your USB keyboard and prefer
112           to use the keyboard in its limited Boot Protocol mode instead.
113
114           This is almost certainly not what you want.  This is mostly
115           useful for embedded applications or simple keyboards.
116
117           To compile this driver as a module, choose M here: the
118           module will be called usbkbd.
119
120           If even remotely unsure, say N.
121
122 config USB_MOUSE
123         tristate "USB HIDBP Mouse (simple Boot) support"
124         depends on USB && INPUT
125         ---help---
126           Say Y here only if you are absolutely sure that you don't want
127           to use the generic HID driver for your USB mouse and prefer
128           to use the mouse in its limited Boot Protocol mode instead.
129
130           This is almost certainly not what you want.  This is mostly
131           useful for embedded applications or simple mice.
132
133           To compile this driver as a module, choose M here: the
134           module will be called usbmouse.
135
136           If even remotely unsure, say N.
137
138 endmenu
139
140 config USB_AIPTEK
141         tristate "Aiptek 6000U/8000U tablet support"
142         depends on USB && INPUT
143         help
144           Say Y here if you want to use the USB version of the Aiptek 6000U
145           or Aiptek 8000U tablet.  Make sure to say Y to "Mouse support"
146           (CONFIG_INPUT_MOUSEDEV) and/or "Event interface support"
147           (CONFIG_INPUT_EVDEV) as well.
148
149           To compile this driver as a module, choose M here: the
150           module will be called aiptek.
151
152 config USB_WACOM
153         tristate "Wacom Intuos/Graphire tablet support"
154         depends on USB && INPUT
155         help
156           Say Y here if you want to use the USB version of the Wacom Intuos
157           or Graphire tablet.  Make sure to say Y to "Mouse support"
158           (CONFIG_INPUT_MOUSEDEV) and/or "Event interface support"
159           (CONFIG_INPUT_EVDEV) as well.
160
161           To compile this driver as a module, choose M here: the
162           module will be called wacom.
163
164 config USB_ACECAD
165         tristate "Acecad Flair tablet support"
166         depends on USB && INPUT
167         help
168           Say Y here if you want to use the USB version of the Acecad Flair
169           tablet.  Make sure to say Y to "Mouse support"
170           (CONFIG_INPUT_MOUSEDEV) and/or "Event interface support"
171           (CONFIG_INPUT_EVDEV) as well.
172
173           To compile this driver as a module, choose M here: the
174           module will be called acecad.
175
176 config USB_KBTAB
177         tristate "KB Gear JamStudio tablet support"
178         depends on USB && INPUT
179         help
180           Say Y here if you want to use the USB version of the KB Gear
181           JamStudio tablet.  Make sure to say Y to "Mouse support"
182           (CONFIG_INPUT_MOUSEDEV) and/or "Event interface support"
183           (CONFIG_INPUT_EVDEV) as well.
184
185           To compile this driver as a module, choose M here: the
186           module will be called kbtab.
187
188 config USB_POWERMATE
189         tristate "Griffin PowerMate and Contour Jog support"
190         depends on USB && INPUT
191         ---help---
192           Say Y here if you want to use Griffin PowerMate or Contour Jog devices.
193           These are aluminum dials which can measure clockwise and anticlockwise
194           rotation.  The dial also acts as a pushbutton.  The base contains an LED
195           which can be instructed to pulse or to switch to a particular intensity.
196
197           You can download userspace tools from
198           <http://sowerbutts.com/powermate/>.
199
200           To compile this driver as a module, choose M here: the
201           module will be called powermate.
202
203 config USB_TOUCHSCREEN
204         tristate "USB Touchscreen Driver"
205         depends on USB && INPUT
206         ---help---
207           USB Touchscreen driver for:
208           - eGalax Touchkit USB
209           - PanJit TouchSet USB
210           - 3M MicroTouch USB
211           - ITM
212
213           Have a look at <http://linux.chapter7.ch/touchkit/> for
214           a usage description and the required user-space stuff.
215
216           To compile this driver as a module, choose M here: the
217           module will be called usbtouchscreen.
218
219 config USB_TOUCHSCREEN_EGALAX
220         default y
221         bool "eGalax device support" if EMBEDDED
222         depends on USB_TOUCHSCREEN
223
224 config USB_TOUCHSCREEN_PANJIT
225         default y
226         bool "PanJit device support" if EMBEDDED
227         depends on USB_TOUCHSCREEN
228
229 config USB_TOUCHSCREEN_3M
230         default y
231         bool "3M/Microtouch device support" if EMBEDDED
232         depends on USB_TOUCHSCREEN
233
234 config USB_TOUCHSCREEN_ITM
235         default y
236         bool "ITM device support" if EMBEDDED
237         depends on USB_TOUCHSCREEN
238
239 config USB_YEALINK
240         tristate "Yealink usb-p1k voip phone"
241         depends on USB && INPUT && EXPERIMENTAL
242         ---help---
243           Say Y here if you want to enable keyboard and LCD functions of the
244           Yealink usb-p1k usb phones. The audio part is enabled by the generic
245           usb sound driver, so you might want to enable that as well.
246
247           For information about how to use these additional functions, see
248           <file:Documentation/input/yealink.txt>.
249
250           To compile this driver as a module, choose M here: the module will be
251           called yealink.
252
253 config USB_XPAD
254         tristate "X-Box gamepad support"
255         depends on USB && INPUT
256         ---help---
257           Say Y here if you want to use the X-Box pad with your computer.
258           Make sure to say Y to "Joystick support" (CONFIG_INPUT_JOYDEV)
259           and/or "Event interface support" (CONFIG_INPUT_EVDEV) as well.
260
261           For information about how to connect the X-Box pad to USB, see
262           <file:Documentation/input/xpad.txt>.
263
264           To compile this driver as a module, choose M here: the
265           module will be called xpad.
266           
267 config USB_ATI_REMOTE
268         tristate "ATI / X10 USB RF remote control"
269         depends on USB && INPUT
270         ---help---
271           Say Y here if you want to use an ATI or X10 "Lola" USB remote control.
272           These are RF remotes with USB receivers. 
273           The ATI remote comes with many of ATI's All-In-Wonder video cards.
274           The X10 "Lola" remote is available at:
275              <http://www.x10.com/products/lola_sg1.htm>
276           This driver provides mouse pointer, left and right mouse buttons, 
277           and maps all the other remote buttons to keypress events.
278           
279           To compile this driver as a module, choose M here: the module will be
280           called ati_remote.
281
282 config USB_ATI_REMOTE2
283         tristate "ATI / Philips USB RF remote control"
284         depends on USB && INPUT
285         ---help---
286           Say Y here if you want to use an ATI or Philips USB RF remote control.
287           These are RF remotes with USB receivers.
288           ATI Remote Wonder II comes with some ATI's All-In-Wonder video cards
289           and is also available as a separate product.
290           This driver provides mouse pointer, left and right mouse buttons,
291           and maps all the other remote buttons to keypress events.
292
293           To compile this driver as a module, choose M here: the module will be
294           called ati_remote2.
295
296 config USB_KEYSPAN_REMOTE
297         tristate "Keyspan DMR USB remote control (EXPERIMENTAL)"
298         depends on USB && INPUT && EXPERIMENTAL
299         ---help---
300           Say Y here if you want to use a Keyspan DMR USB remote control.
301           Currently only the UIA-11 type of receiver has been tested.  The tag
302           on the receiver that connects to the USB port should have a P/N that
303           will tell you what type of DMR you have.  The UIA-10 type is not
304           supported at this time.  This driver maps all buttons to keypress
305           events.
306
307           To compile this driver as a module, choose M here: the module will
308           be called keyspan_remote.
309
310 config USB_APPLETOUCH
311         tristate "Apple USB Touchpad support"
312         depends on USB && INPUT
313         ---help---
314           Say Y here if you want to use an Apple USB Touchpad.
315
316           These are the touchpads that can be found on post-February 2005
317           Apple Powerbooks (prior models have a Synaptics touchpad connected
318           to the ADB bus).
319
320           This driver provides a basic mouse driver but can be interfaced
321           with the synaptics X11 driver to provide acceleration and
322           scrolling in X11.
323
324           For further information, see
325           <file:Documentation/input/appletouch.txt>.
326
327           To compile this driver as a module, choose M here: the
328           module will be called appletouch.