Blame view

include/linux/hid.h 34.5 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2
3
   *  Copyright (c) 1999 Andreas Gal
   *  Copyright (c) 2000-2001 Vojtech Pavlik
b55fd23cc   Jiri Kosina   HID: fix broken L...
4
   *  Copyright (c) 2006-2007 Jiri Kosina
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
5
   */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
  /*
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License as published by
   * the Free Software Foundation; either version 2 of the License, or
   * (at your option) any later version.
   *
   * This program is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   * GNU General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * along with this program; if not, write to the Free Software
   * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
   *
   * Should you need to contact me, the author, you can do so either by
   * e-mail - mail your message to <vojtech@ucw.cz>, or by paper mail:
   * Vojtech Pavlik, Simunkova 1594, Prague 8, 182 00 Czech Republic
   */
607ca46e9   David Howells   UAPI: (Scripted) ...
25
26
  #ifndef __HID_H
  #define __HID_H
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
27

57d292bd7   Jiri Kosina   HID: fix HIDIOCGR...
28
29
30
31
  
  #include <linux/types.h>
  #include <linux/slab.h>
  #include <linux/list.h>
e8c84f9a5   Jiri Slaby   modpost: add supp...
32
  #include <linux/mod_devicetable.h> /* hid_device_id */
57d292bd7   Jiri Kosina   HID: fix HIDIOCGR...
33
34
35
  #include <linux/timer.h>
  #include <linux/workqueue.h>
  #include <linux/input.h>
4ea545420   David Herrmann   HID: Fix race con...
36
  #include <linux/semaphore.h>
4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
37
  #include <linux/power_supply.h>
607ca46e9   David Howells   UAPI: (Scripted) ...
38
  #include <uapi/linux/hid.h>
57d292bd7   Jiri Kosina   HID: fix HIDIOCGR...
39

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
  /*
   * We parse each description item into this structure. Short items data
   * values are expanded to 32-bit signed int, long items contain a pointer
   * into the data area.
   */
  
  struct hid_item {
  	unsigned  format;
  	__u8      size;
  	__u8      type;
  	__u8      tag;
  	union {
  	    __u8   u8;
  	    __s8   s8;
  	    __u16  u16;
  	    __s16  s16;
  	    __u32  u32;
  	    __s32  s32;
  	    __u8  *longdata;
  	} data;
  };
  
  /*
   * HID report item format
   */
  
  #define HID_ITEM_FORMAT_SHORT	0
  #define HID_ITEM_FORMAT_LONG	1
  
  /*
   * Special tag indicating long items
   */
  
  #define HID_ITEM_TAG_LONG	15
  
  /*
   * HID report descriptor item type (prefix bit 2,3)
   */
  
  #define HID_ITEM_TYPE_MAIN		0
  #define HID_ITEM_TYPE_GLOBAL		1
  #define HID_ITEM_TYPE_LOCAL		2
  #define HID_ITEM_TYPE_RESERVED		3
  
  /*
   * HID report descriptor main item tags
   */
  
  #define HID_MAIN_ITEM_TAG_INPUT			8
  #define HID_MAIN_ITEM_TAG_OUTPUT		9
  #define HID_MAIN_ITEM_TAG_FEATURE		11
  #define HID_MAIN_ITEM_TAG_BEGIN_COLLECTION	10
  #define HID_MAIN_ITEM_TAG_END_COLLECTION	12
  
  /*
   * HID report descriptor main item contents
   */
  
  #define HID_MAIN_ITEM_CONSTANT		0x001
  #define HID_MAIN_ITEM_VARIABLE		0x002
  #define HID_MAIN_ITEM_RELATIVE		0x004
05f091ab4   Dmitry Torokhov   Input: whitespace...
101
  #define HID_MAIN_ITEM_WRAP		0x008
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
  #define HID_MAIN_ITEM_NONLINEAR		0x010
  #define HID_MAIN_ITEM_NO_PREFERRED	0x020
  #define HID_MAIN_ITEM_NULL_STATE	0x040
  #define HID_MAIN_ITEM_VOLATILE		0x080
  #define HID_MAIN_ITEM_BUFFERED_BYTE	0x100
  
  /*
   * HID report descriptor collection item types
   */
  
  #define HID_COLLECTION_PHYSICAL		0
  #define HID_COLLECTION_APPLICATION	1
  #define HID_COLLECTION_LOGICAL		2
  
  /*
   * HID report descriptor global item tags
   */
  
  #define HID_GLOBAL_ITEM_TAG_USAGE_PAGE		0
  #define HID_GLOBAL_ITEM_TAG_LOGICAL_MINIMUM	1
  #define HID_GLOBAL_ITEM_TAG_LOGICAL_MAXIMUM	2
  #define HID_GLOBAL_ITEM_TAG_PHYSICAL_MINIMUM	3
  #define HID_GLOBAL_ITEM_TAG_PHYSICAL_MAXIMUM	4
  #define HID_GLOBAL_ITEM_TAG_UNIT_EXPONENT	5
  #define HID_GLOBAL_ITEM_TAG_UNIT		6
  #define HID_GLOBAL_ITEM_TAG_REPORT_SIZE		7
  #define HID_GLOBAL_ITEM_TAG_REPORT_ID		8
  #define HID_GLOBAL_ITEM_TAG_REPORT_COUNT	9
  #define HID_GLOBAL_ITEM_TAG_PUSH		10
  #define HID_GLOBAL_ITEM_TAG_POP			11
  
  /*
   * HID report descriptor local item tags
   */
  
  #define HID_LOCAL_ITEM_TAG_USAGE		0
  #define HID_LOCAL_ITEM_TAG_USAGE_MINIMUM	1
  #define HID_LOCAL_ITEM_TAG_USAGE_MAXIMUM	2
  #define HID_LOCAL_ITEM_TAG_DESIGNATOR_INDEX	3
  #define HID_LOCAL_ITEM_TAG_DESIGNATOR_MINIMUM	4
  #define HID_LOCAL_ITEM_TAG_DESIGNATOR_MAXIMUM	5
  #define HID_LOCAL_ITEM_TAG_STRING_INDEX		7
  #define HID_LOCAL_ITEM_TAG_STRING_MINIMUM	8
  #define HID_LOCAL_ITEM_TAG_STRING_MAXIMUM	9
  #define HID_LOCAL_ITEM_TAG_DELIMITER		10
  
  /*
   * HID usage tables
   */
  
  #define HID_USAGE_PAGE		0xffff0000
  
  #define HID_UP_UNDEFINED	0x00000000
05f091ab4   Dmitry Torokhov   Input: whitespace...
155
  #define HID_UP_GENDESK		0x00010000
0aebfdac0   Vojtech Pavlik   Input: add HID si...
156
  #define HID_UP_SIMULATION	0x00020000
4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
157
  #define HID_UP_GENDEVCTRLS	0x00060000
05f091ab4   Dmitry Torokhov   Input: whitespace...
158
159
160
161
  #define HID_UP_KEYBOARD		0x00070000
  #define HID_UP_LED		0x00080000
  #define HID_UP_BUTTON		0x00090000
  #define HID_UP_ORDINAL		0x000a0000
f3dddf243   Dmitry Torokhov   HID: map telephon...
162
  #define HID_UP_TELEPHONY	0x000b0000
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
163
  #define HID_UP_CONSUMER		0x000c0000
05f091ab4   Dmitry Torokhov   Input: whitespace...
164
165
  #define HID_UP_DIGITIZER	0x000d0000
  #define HID_UP_PID		0x000f0000
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
166
  #define HID_UP_HPVENDOR         0xff7f0000
929578ab0   Keng-Yu Lin   HID: Add suport f...
167
  #define HID_UP_HPVENDOR2        0xff010000
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
168
  #define HID_UP_MSVENDOR		0xff000000
e875ce374   Stelian Pop   Input: HID - add ...
169
170
  #define HID_UP_CUSTOM		0x00ff0000
  #define HID_UP_LOGIVENDOR	0xffbc0000
b466c1dd7   Simon Wood   HID: Add vendor s...
171
172
  #define HID_UP_LOGIVENDOR2   0xff090000
  #define HID_UP_LOGIVENDOR3   0xff430000
f3d4ff0e0   Jamie Lentin   HID: lenovo: Add ...
173
  #define HID_UP_LNVENDOR		0xffa00000
83499b52c   Alexander Holler   HID: sensors: aut...
174
  #define HID_UP_SENSOR		0x00200000
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
  
  #define HID_USAGE		0x0000ffff
  
  #define HID_GD_POINTER		0x00010001
  #define HID_GD_MOUSE		0x00010002
  #define HID_GD_JOYSTICK		0x00010004
  #define HID_GD_GAMEPAD		0x00010005
  #define HID_GD_KEYBOARD		0x00010006
  #define HID_GD_KEYPAD		0x00010007
  #define HID_GD_MULTIAXIS	0x00010008
  #define HID_GD_X		0x00010030
  #define HID_GD_Y		0x00010031
  #define HID_GD_Z		0x00010032
  #define HID_GD_RX		0x00010033
  #define HID_GD_RY		0x00010034
  #define HID_GD_RZ		0x00010035
  #define HID_GD_SLIDER		0x00010036
  #define HID_GD_DIAL		0x00010037
  #define HID_GD_WHEEL		0x00010038
  #define HID_GD_HATSWITCH	0x00010039
  #define HID_GD_BUFFER		0x0001003a
  #define HID_GD_BYTECOUNT	0x0001003b
  #define HID_GD_MOTION		0x0001003c
  #define HID_GD_START		0x0001003d
  #define HID_GD_SELECT		0x0001003e
  #define HID_GD_VX		0x00010040
  #define HID_GD_VY		0x00010041
  #define HID_GD_VZ		0x00010042
  #define HID_GD_VBRX		0x00010043
  #define HID_GD_VBRY		0x00010044
  #define HID_GD_VBRZ		0x00010045
  #define HID_GD_VNO		0x00010046
  #define HID_GD_FEATURE		0x00010047
6aef704e3   Benjamin Tissoires   HID: multitouch: ...
208
  #define HID_GD_SYSTEM_CONTROL	0x00010080
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
209
210
211
212
  #define HID_GD_UP		0x00010090
  #define HID_GD_DOWN		0x00010091
  #define HID_GD_RIGHT		0x00010092
  #define HID_GD_LEFT		0x00010093
4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
213
  #define HID_DC_BATTERYSTRENGTH	0x00060020
6aef704e3   Benjamin Tissoires   HID: multitouch: ...
214
  #define HID_CP_CONSUMER_CONTROL	0x000c0001
89f536ccf   Stephane Chatty   HID: add new mult...
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
  #define HID_DG_DIGITIZER	0x000d0001
  #define HID_DG_PEN		0x000d0002
  #define HID_DG_LIGHTPEN		0x000d0003
  #define HID_DG_TOUCHSCREEN	0x000d0004
  #define HID_DG_TOUCHPAD		0x000d0005
  #define HID_DG_STYLUS		0x000d0020
  #define HID_DG_PUCK		0x000d0021
  #define HID_DG_FINGER		0x000d0022
  #define HID_DG_TIPPRESSURE	0x000d0030
  #define HID_DG_BARRELPRESSURE	0x000d0031
  #define HID_DG_INRANGE		0x000d0032
  #define HID_DG_TOUCH		0x000d0033
  #define HID_DG_UNTOUCH		0x000d0034
  #define HID_DG_TAP		0x000d0035
  #define HID_DG_TABLETFUNCTIONKEY	0x000d0039
  #define HID_DG_PROGRAMCHANGEKEY	0x000d003a
  #define HID_DG_INVERT		0x000d003c
  #define HID_DG_TIPSWITCH	0x000d0042
  #define HID_DG_TIPSWITCH2	0x000d0043
  #define HID_DG_BARRELSWITCH	0x000d0044
  #define HID_DG_ERASER		0x000d0045
  #define HID_DG_TABLETPICK	0x000d0046
1a3f83f64   JD Cole   HID: plantronics:...
237
238
  
  #define HID_CP_CONSUMERCONTROL	0x000c0001
a45c30ec5   JD Cole   HID: added missin...
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
  #define HID_CP_NUMERICKEYPAD	0x000c0002
  #define HID_CP_PROGRAMMABLEBUTTONS	0x000c0003
  #define HID_CP_MICROPHONE	0x000c0004
  #define HID_CP_HEADPHONE	0x000c0005
  #define HID_CP_GRAPHICEQUALIZER	0x000c0006
  #define HID_CP_FUNCTIONBUTTONS	0x000c0036
  #define HID_CP_SELECTION	0x000c0080
  #define HID_CP_MEDIASELECTION	0x000c0087
  #define HID_CP_SELECTDISC	0x000c00ba
  #define HID_CP_PLAYBACKSPEED	0x000c00f1
  #define HID_CP_PROXIMITY	0x000c0109
  #define HID_CP_SPEAKERSYSTEM	0x000c0160
  #define HID_CP_CHANNELLEFT	0x000c0161
  #define HID_CP_CHANNELRIGHT	0x000c0162
  #define HID_CP_CHANNELCENTER	0x000c0163
  #define HID_CP_CHANNELFRONT	0x000c0164
  #define HID_CP_CHANNELCENTERFRONT	0x000c0165
  #define HID_CP_CHANNELSIDE	0x000c0166
  #define HID_CP_CHANNELSURROUND	0x000c0167
  #define HID_CP_CHANNELLOWFREQUENCYENHANCEMENT	0x000c0168
  #define HID_CP_CHANNELTOP	0x000c0169
  #define HID_CP_CHANNELUNKNOWN	0x000c016a
  #define HID_CP_APPLICATIONLAUNCHBUTTONS	0x000c0180
  #define HID_CP_GENERICGUIAPPLICATIONCONTROLS	0x000c0200
1a3f83f64   JD Cole   HID: plantronics:...
263

89f536ccf   Stephane Chatty   HID: add new mult...
264
265
266
267
268
269
270
271
  #define HID_DG_CONFIDENCE	0x000d0047
  #define HID_DG_WIDTH		0x000d0048
  #define HID_DG_HEIGHT		0x000d0049
  #define HID_DG_CONTACTID	0x000d0051
  #define HID_DG_INPUTMODE	0x000d0052
  #define HID_DG_DEVICEINDEX	0x000d0053
  #define HID_DG_CONTACTCOUNT	0x000d0054
  #define HID_DG_CONTACTMAX	0x000d0055
2c6e0277e   Seth Forshee   HID: multitouch: ...
272
  #define HID_DG_BUTTONTYPE	0x000d0059
368c96640   Ping Cheng   HID: core: add tw...
273
274
  #define HID_DG_BARRELSWITCH2	0x000d005a
  #define HID_DG_TOOLSERIALNUMBER	0x000d005b
89f536ccf   Stephane Chatty   HID: add new mult...
275

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
276
277
278
279
280
281
282
  /*
   * HID report types --- Ouch! HID spec says 1 2 3!
   */
  
  #define HID_INPUT_REPORT	0
  #define HID_OUTPUT_REPORT	1
  #define HID_FEATURE_REPORT	2
39054a5af   David Herrmann   HID: move HID_REP...
283
  #define HID_REPORT_TYPES	3
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
284
  /*
93c10132a   Jiri Slaby   HID: move connect...
285
286
287
288
289
290
291
292
293
   * HID connect requests
   */
  
  #define HID_CONNECT_HIDINPUT		0x01
  #define HID_CONNECT_HIDINPUT_FORCE	0x02
  #define HID_CONNECT_HIDRAW		0x04
  #define HID_CONNECT_HIDDEV		0x08
  #define HID_CONNECT_HIDDEV_FORCE	0x10
  #define HID_CONNECT_FF			0x20
7704ac937   Benjamin Tissoires   HID: wacom: imple...
294
  #define HID_CONNECT_DRIVER		0x40
93c10132a   Jiri Slaby   HID: move connect...
295
296
297
298
  #define HID_CONNECT_DEFAULT	(HID_CONNECT_HIDINPUT|HID_CONNECT_HIDRAW| \
  		HID_CONNECT_HIDDEV|HID_CONNECT_FF)
  
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
299
300
   * HID device quirks.
   */
876b9276b   Paul Walmsley   USB HID: add 'qui...
301
302
303
304
  /* 
   * Increase this if you need to configure more HID quirks at module load time
   */
  #define MAX_USBHID_BOOT_QUIRKS 4
eab9edd27   Michael Hanselmann   Input: HID - add ...
305
306
  #define HID_QUIRK_INVERT			0x00000001
  #define HID_QUIRK_NOTOUCH			0x00000002
6f4303fb2   Jiri Kosina   HID: bring back p...
307
  #define HID_QUIRK_IGNORE			0x00000004
eab9edd27   Michael Hanselmann   Input: HID - add ...
308
  #define HID_QUIRK_NOGET				0x00000008
b5e5a37e3   Bastien Nocera   HID: add HID_QUIR...
309
  #define HID_QUIRK_HIDDEV_FORCE			0x00000010
eab9edd27   Michael Hanselmann   Input: HID - add ...
310
311
  #define HID_QUIRK_BADPAD			0x00000020
  #define HID_QUIRK_MULTI_INPUT			0x00000040
3a343ee45   Daniel Mack   HID: add HID_QUIR...
312
  #define HID_QUIRK_HIDINPUT_FORCE		0x00000080
4f22decf9   Benjamin Tissoires   HID: input: don't...
313
  #define HID_QUIRK_NO_EMPTY_INPUT		0x00000100
595e9276c   Benjamin Tissoires   HID: do not init ...
314
  #define HID_QUIRK_NO_INIT_INPUT_REPORTS		0x00000200
0b750b3ba   Johan Hovold   HID: usbhid: add ...
315
  #define HID_QUIRK_ALWAYS_POLL			0x00000400
ea9a4a8b0   Jiri Kosina   HID: separate qui...
316
  #define HID_QUIRK_SKIP_OUTPUT_REPORTS		0x00010000
e534a9352   Benjamin Tissoires   HID: sony: do not...
317
318
  #define HID_QUIRK_SKIP_OUTPUT_REPORT_ID		0x00020000
  #define HID_QUIRK_NO_OUTPUT_REPORTS_ON_INTR_EP	0x00040000
f345c37c3   Pekka Sarnila   HID: fixup fullsp...
319
  #define HID_QUIRK_FULLSPEED_INTERVAL		0x10000000
5b915d9e6   Jiri Kosina   HID: fixup quirk ...
320
  #define HID_QUIRK_NO_INIT_REPORTS		0x20000000
b5e5a37e3   Bastien Nocera   HID: add HID_QUIR...
321
  #define HID_QUIRK_NO_IGNORE			0x40000000
24750f3e4   Henrik Rydberg   HID: Add a hid qu...
322
  #define HID_QUIRK_NO_INPUT_SYNC			0x80000000
ea9a4a8b0   Jiri Kosina   HID: separate qui...
323
324
  
  /*
734c66093   Henrik Rydberg   HID: Scan the dev...
325
   * HID device groups
ba391e5a5   Benjamin Tissoires   HID: rmi: do not ...
326
327
328
   *
   * Note: HID_GROUP_ANY is declared in linux/mod_devicetable.h
   * and has a value of 0x0000
734c66093   Henrik Rydberg   HID: Scan the dev...
329
330
   */
  #define HID_GROUP_GENERIC			0x0001
4fa3a5837   Henrik Rydberg   HID: hid-multitou...
331
  #define HID_GROUP_MULTITOUCH			0x0002
83499b52c   Alexander Holler   HID: sensors: aut...
332
  #define HID_GROUP_SENSOR_HUB			0x0003
f961bd351   Benjamin Tissoires   HID: detect Win 8...
333
  #define HID_GROUP_MULTITOUCH_WIN_8		0x0004
734c66093   Henrik Rydberg   HID: Scan the dev...
334
335
  
  /*
ba391e5a5   Benjamin Tissoires   HID: rmi: do not ...
336
337
338
   * Vendor specific HID device groups
   */
  #define HID_GROUP_RMI				0x0100
29b473913   Benjamin Tissoires   Input: wacom - sw...
339
  #define HID_GROUP_WACOM				0x0101
d610274b0   Benjamin Tissoires   HID: logitech-dj:...
340
  #define HID_GROUP_LOGITECH_DJ_DEVICE		0x0102
29b473913   Benjamin Tissoires   Input: wacom - sw...
341
342
  
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
   * This is the global environment of the parser. This information is
   * persistent for main-items. The global environment can be saved and
   * restored with PUSH/POP statements.
   */
  
  struct hid_global {
  	unsigned usage_page;
  	__s32    logical_minimum;
  	__s32    logical_maximum;
  	__s32    physical_minimum;
  	__s32    physical_maximum;
  	__s32    unit_exponent;
  	unsigned unit;
  	unsigned report_id;
  	unsigned report_size;
  	unsigned report_count;
  };
  
  /*
   * This is the local environment. It is persistent up the next main-item.
   */
5f1ab74f6   Jiri Kosina   HID: Sunplus Wire...
364
  #define HID_MAX_USAGES			12288
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
  #define HID_DEFAULT_NUM_COLLECTIONS	16
  
  struct hid_local {
  	unsigned usage[HID_MAX_USAGES]; /* usage array */
  	unsigned collection_index[HID_MAX_USAGES]; /* collection index array */
  	unsigned usage_index;
  	unsigned usage_minimum;
  	unsigned delimiter_depth;
  	unsigned delimiter_branch;
  };
  
  /*
   * This is the collection stack. We climb up the stack to determine
   * application and function of each field.
   */
  
  struct hid_collection {
  	unsigned type;
  	unsigned usage;
  	unsigned level;
  };
  
  struct hid_usage {
  	unsigned  hid;			/* hid usage code */
  	unsigned  collection_index;	/* index into collection array */
f262d1fa2   Benjamin Tissoires   HID: add usage_in...
390
  	unsigned  usage_index;		/* index into usage array */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
  	/* hidinput data */
  	__u16     code;			/* input driver code */
  	__u8      type;			/* input driver type */
  	__s8	  hat_min;		/* hat switch fun */
  	__s8	  hat_max;		/* ditto */
  	__s8	  hat_dir;		/* ditto */
  };
  
  struct hid_input;
  
  struct hid_field {
  	unsigned  physical;		/* physical usage for this field */
  	unsigned  logical;		/* logical usage for this field */
  	unsigned  application;		/* application usage for this field */
  	struct hid_usage *usage;	/* usage table for this function */
  	unsigned  maxusage;		/* maximum usage index */
  	unsigned  flags;		/* main-item flags (i.e. volatile,array,constant) */
  	unsigned  report_offset;	/* bit offset in the report */
  	unsigned  report_size;		/* size of this field in the report */
  	unsigned  report_count;		/* number of this field in the report */
  	unsigned  report_type;		/* (input,output,feature) */
  	__s32    *value;		/* last known value(s) */
  	__s32     logical_minimum;
  	__s32     logical_maximum;
  	__s32     physical_minimum;
  	__s32     physical_maximum;
  	__s32     unit_exponent;
  	unsigned  unit;
  	struct hid_report *report;	/* associated report */
  	unsigned index;			/* index into report->field[] */
  	/* hidinput data */
  	struct hid_input *hidinput;	/* associated input structure */
  	__u16 dpad;			/* dpad input code */
  };
7e55bdedf   Henrik Rydberg   HID: Allow more f...
425
  #define HID_MAX_FIELDS 256
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
426
427
428
429
430
431
432
433
434
435
  
  struct hid_report {
  	struct list_head list;
  	unsigned id;					/* id of this report */
  	unsigned type;					/* report type */
  	struct hid_field *field[HID_MAX_FIELDS];	/* fields of the report */
  	unsigned maxfield;				/* maximum valid field index */
  	unsigned size;					/* size of the report (bits) */
  	struct hid_device *device;			/* associated device */
  };
43622021d   Kees Cook   HID: validate HID...
436
  #define HID_MAX_IDS 256
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
437
438
439
  struct hid_report_enum {
  	unsigned numbered;
  	struct list_head report_list;
43622021d   Kees Cook   HID: validate HID...
440
  	struct hid_report *report_id_hash[HID_MAX_IDS];
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
441
  };
bf0964dcd   Michael Haboustak   Input: HID - hand...
442
443
  #define HID_MIN_BUFFER_SIZE	64		/* make sure there is at least a packet size of space */
  #define HID_MAX_BUFFER_SIZE	4096		/* 4kb */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
444
445
446
447
448
449
  #define HID_CONTROL_FIFO_SIZE	256		/* to init devices with >100 reports */
  #define HID_OUTPUT_FIFO_SIZE	64
  
  struct hid_control_fifo {
  	unsigned char dir;
  	struct hid_report *report;
f129ea6d1   Anssi Hannula   HID: fix a lockup...
450
451
452
453
454
455
  	char *raw_report;
  };
  
  struct hid_output_fifo {
  	struct hid_report *report;
  	char *raw_report;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
456
457
458
459
  };
  
  #define HID_CLAIMED_INPUT	1
  #define HID_CLAIMED_HIDDEV	2
86166b7bc   Jiri Kosina   HID: add hidraw i...
460
  #define HID_CLAIMED_HIDRAW	4
7704ac937   Benjamin Tissoires   HID: wacom: imple...
461
  #define HID_CLAIMED_DRIVER	8
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
462

85cdaf524   Jiri Slaby   HID: make a bus f...
463
  #define HID_STAT_ADDED		1
c500c9714   Jiri Slaby   HID: hid, make pa...
464
  #define HID_STAT_PARSED		2
85cdaf524   Jiri Slaby   HID: make a bus f...
465

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
466
467
468
  struct hid_input {
  	struct list_head list;
  	struct hid_report *report;
c5b7c7c39   Dmitry Torokhov   [PATCH] drivers/u...
469
  	struct input_dev *input;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
470
  };
a73a63701   Jiri Slaby   HID: add hid_type...
471
472
  enum hid_type {
  	HID_TYPE_OTHER = 0,
6dc1418e1   Tomoki Sekiyama   HID: yurex: recog...
473
474
  	HID_TYPE_USBMOUSE,
  	HID_TYPE_USBNONE
a73a63701   Jiri Slaby   HID: add hid_type...
475
  };
85cdaf524   Jiri Slaby   HID: make a bus f...
476
  struct hid_driver;
c500c9714   Jiri Slaby   HID: hid, make pa...
477
  struct hid_ll_driver;
85cdaf524   Jiri Slaby   HID: make a bus f...
478

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
479
  struct hid_device {							/* device report descriptor */
a7197c2e4   Henrik Rydberg   HID: Handle drive...
480
481
  	__u8 *dev_rdesc;
  	unsigned dev_rsize;
85cdaf524   Jiri Slaby   HID: make a bus f...
482
  	__u8 *rdesc;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
483
484
485
486
487
  	unsigned rsize;
  	struct hid_collection *collection;				/* List of HID collections */
  	unsigned collection_size;					/* Number of allocated hid_collections */
  	unsigned maxcollection;						/* Number of parsed collections */
  	unsigned maxapplication;					/* Number of applications */
85cdaf524   Jiri Slaby   HID: make a bus f...
488
  	__u16 bus;							/* BUS ID */
4d53b8012   Henrik Rydberg   HID: Add device g...
489
  	__u16 group;							/* Report group */
85cdaf524   Jiri Slaby   HID: make a bus f...
490
491
492
  	__u32 vendor;							/* Vendor ID */
  	__u32 product;							/* Product ID */
  	__u32 version;							/* HID version */
a73a63701   Jiri Slaby   HID: add hid_type...
493
  	enum hid_type type;						/* device type (mouse, kbd, ...) */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
494
495
  	unsigned country;						/* HID country */
  	struct hid_report_enum report_enum[HID_REPORT_TYPES];
50c9d75b6   David Herrmann   HID: input: gener...
496
  	struct work_struct led_work;					/* delayed LED worker */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
497

c849a6143   Andrew de los Reyes   HID: Separate str...
498
499
  	struct semaphore driver_lock;					/* protects the current driver, except during input */
  	struct semaphore driver_input_lock;				/* protects the current driver */
85cdaf524   Jiri Slaby   HID: make a bus f...
500
501
  	struct device dev;						/* device */
  	struct hid_driver *driver;
c500c9714   Jiri Slaby   HID: hid, make pa...
502
  	struct hid_ll_driver *ll_driver;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
503

4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
504
505
506
  #ifdef CONFIG_HID_BATTERY_STRENGTH
  	/*
  	 * Power supply information for HID devices which report
297d716f6   Krzysztof Kozlowski   power_supply: Cha...
507
508
  	 * battery strength. power_supply was successfully registered if
  	 * battery is non-NULL.
4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
509
  	 */
297d716f6   Krzysztof Kozlowski   power_supply: Cha...
510
  	struct power_supply *battery;
4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
511
512
  	__s32 battery_min;
  	__s32 battery_max;
fb8ac91b4   Jeremy Fitzhardinge   hid-input/battery...
513
  	__s32 battery_report_type;
c5a92aa3e   Daniel Nicoletti   hid-input: add su...
514
  	__s32 battery_report_id;
4f5ca836b   Jeremy Fitzhardinge   HID: hid-input: a...
515
  #endif
85cdaf524   Jiri Slaby   HID: make a bus f...
516
  	unsigned int status;						/* see STAT flags above */
05f091ab4   Dmitry Torokhov   Input: whitespace...
517
  	unsigned claimed;						/* Claimed by hidinput, hiddev? */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
518
  	unsigned quirks;						/* Various quirks the device can pull on us */
c849a6143   Andrew de los Reyes   HID: Separate str...
519
  	bool io_started;						/* Protected by driver_lock. If IO has started */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
520
521
522
  
  	struct list_head inputs;					/* The list of inputs */
  	void *hiddev;							/* The hiddev structure */
86166b7bc   Jiri Kosina   HID: add hidraw i...
523
  	void *hidraw;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
524
  	int minor;							/* Hiddev minor number */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
525
526
527
528
  	int open;							/* is the device open by anyone? */
  	char name[128];							/* Device name */
  	char phys[64];							/* Device physical location */
  	char uniq[64];							/* Device unique identifier (serial #) */
229695e51   Jiri Kosina   [PATCH] Generic H...
529
  	void *driver_data;
93c10132a   Jiri Slaby   HID: move connect...
530
531
  	/* temporary hid_ff handling (until moved to the drivers) */
  	int (*ff_init)(struct hid_device *);
aa938f797   Jiri Kosina   [PATCH] Generic H...
532
  	/* hiddev event handler */
93c10132a   Jiri Slaby   HID: move connect...
533
  	int (*hiddev_connect)(struct hid_device *, unsigned int);
c4c259bcc   Jiri Kosina   HID: consolidate ...
534
  	void (*hiddev_disconnect)(struct hid_device *);
aa938f797   Jiri Kosina   [PATCH] Generic H...
535
536
  	void (*hiddev_hid_event) (struct hid_device *, struct hid_field *field,
  				  struct hid_usage *, __s32);
aa8de2f03   Jiri Kosina   [PATCH] Generic H...
537
  	void (*hiddev_report_event) (struct hid_device *, struct hid_report *);
86166b7bc   Jiri Kosina   HID: add hidraw i...
538

cd667ce24   Jiri Kosina   HID: use debugfs ...
539
540
541
542
543
544
  	/* debugging support via debugfs */
  	unsigned short debug;
  	struct dentry *debug_dir;
  	struct dentry *debug_rdesc;
  	struct dentry *debug_events;
  	struct list_head debug_list;
1deb9d341   Jiri Kosina   HID: debug: fix R...
545
  	spinlock_t  debug_list_lock;
cd667ce24   Jiri Kosina   HID: use debugfs ...
546
  	wait_queue_head_t debug_wait;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
547
  };
d8ce9bf55   Geliang Tang   HID: move to_hid_...
548
549
  #define to_hid_device(pdev) \
  	container_of(pdev, struct hid_device, dev)
85cdaf524   Jiri Slaby   HID: make a bus f...
550
551
552
553
554
555
556
557
558
  static inline void *hid_get_drvdata(struct hid_device *hdev)
  {
  	return dev_get_drvdata(&hdev->dev);
  }
  
  static inline void hid_set_drvdata(struct hid_device *hdev, void *data)
  {
  	dev_set_drvdata(&hdev->dev, data);
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
559
560
  #define HID_GLOBAL_STACK_SIZE 4
  #define HID_COLLECTION_STACK_SIZE 4
e39f2d595   Andrew Duggan   HID: rmi: Scan th...
561
562
563
  #define HID_SCAN_FLAG_MT_WIN_8			BIT(0)
  #define HID_SCAN_FLAG_VENDOR_SPECIFIC		BIT(1)
  #define HID_SCAN_FLAG_GD_POINTER		BIT(2)
f961bd351   Benjamin Tissoires   HID: detect Win 8...
564

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
565
566
567
568
569
570
571
572
  struct hid_parser {
  	struct hid_global     global;
  	struct hid_global     global_stack[HID_GLOBAL_STACK_SIZE];
  	unsigned              global_stack_ptr;
  	struct hid_local      local;
  	unsigned              collection_stack[HID_COLLECTION_STACK_SIZE];
  	unsigned              collection_stack_ptr;
  	struct hid_device    *device;
f961bd351   Benjamin Tissoires   HID: detect Win 8...
573
  	unsigned              scan_flags;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
574
575
576
577
  };
  
  struct hid_class_descriptor {
  	__u8  bDescriptorType;
01d7b3698   Al Viro   usbhid endianness...
578
  	__le16 wDescriptorLength;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
579
580
581
582
583
  } __attribute__ ((packed));
  
  struct hid_descriptor {
  	__u8  bLength;
  	__u8  bDescriptorType;
01d7b3698   Al Viro   usbhid endianness...
584
  	__le16 bcdHID;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
585
586
587
588
589
  	__u8  bCountryCode;
  	__u8  bNumDescriptors;
  
  	struct hid_class_descriptor desc[1];
  } __attribute__ ((packed));
070748ed0   Henrik Rydberg   HID: Create a gen...
590
591
592
593
594
595
  #define HID_DEVICE(b, g, ven, prod)					\
  	.bus = (b), .group = (g), .vendor = (ven), .product = (prod)
  #define HID_USB_DEVICE(ven, prod)				\
  	.bus = BUS_USB, .vendor = (ven), .product = (prod)
  #define HID_BLUETOOTH_DEVICE(ven, prod)					\
  	.bus = BUS_BLUETOOTH, .vendor = (ven), .product = (prod)
9fb6bf02e   Benjamin Tissoires   HID: rmi: introdu...
596
597
  #define HID_I2C_DEVICE(ven, prod)				\
  	.bus = BUS_I2C, .vendor = (ven), .product = (prod)
85cdaf524   Jiri Slaby   HID: make a bus f...
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
  
  #define HID_REPORT_ID(rep) \
  	.report_type = (rep)
  #define HID_USAGE_ID(uhid, utype, ucode) \
  	.usage_hid = (uhid), .usage_type = (utype), .usage_code = (ucode)
  /* we don't want to catch types and codes equal to 0 */
  #define HID_TERMINATOR		(HID_ANY_ID - 1)
  
  struct hid_report_id {
  	__u32 report_type;
  };
  struct hid_usage_id {
  	__u32 usage_hid;
  	__u32 usage_type;
  	__u32 usage_code;
  };
  
  /**
   * struct hid_driver
   * @name: driver name (e.g. "Footech_bar-wheel")
   * @id_table: which devices is this driver for (must be non-NULL for probe
   * 	      to be called)
3a6f82f7a   Jiri Slaby   HID: add dynids f...
620
621
   * @dyn_list: list of dynamically added device ids
   * @dyn_lock: lock protecting @dyn_list
85cdaf524   Jiri Slaby   HID: make a bus f...
622
623
624
625
626
627
   * @probe: new device inserted
   * @remove: device removed (NULL if not a hot-plug capable driver)
   * @report_table: on which reports to call raw_event (NULL means all)
   * @raw_event: if report in report_table, this hook is called (NULL means nop)
   * @usage_table: on which events to call event (NULL means all)
   * @event: if usage in usage_table, this hook is called (NULL means nop)
6d85d037d   Benjamin Tissoires   HID: core: add "r...
628
   * @report: this hook is called after parsing a report (NULL means nop)
c500c9714   Jiri Slaby   HID: hid, make pa...
629
630
631
   * @report_fixup: called before report descriptor parsing (NULL means nop)
   * @input_mapping: invoked on input registering before mapping an usage
   * @input_mapped: invoked on input registering after mapping an usage
9ebf3d768   Henrik Rydberg   HID: Add an input...
632
   * @input_configured: invoked just before the device is registered
0d2689c0f   Benjamin Tissoires   HID: add feature_...
633
   * @feature_mapping: invoked on feature registering
6a740aa4f   Bruno Prémont   HID: add suspend/...
634
635
636
   * @suspend: invoked on suspend (NULL means nop)
   * @resume: invoked on resume if device was not reset (NULL means nop)
   * @reset_resume: invoked on resume if device was reset (NULL means nop)
85cdaf524   Jiri Slaby   HID: make a bus f...
637
   *
c849a6143   Andrew de los Reyes   HID: Separate str...
638
639
640
641
   * probe should return -errno on error, or 0 on success. During probe,
   * input will not be passed to raw_event unless hid_device_io_start is
   * called.
   *
85cdaf524   Jiri Slaby   HID: make a bus f...
642
643
   * raw_event and event should return 0 on no action performed, 1 when no
   * further processing should be done and negative on error
c500c9714   Jiri Slaby   HID: hid, make pa...
644
645
646
647
648
649
650
651
652
653
   *
   * input_mapping shall return a negative value to completely ignore this usage
   * (e.g. doubled or invalid usage), zero to continue with parsing of this
   * usage by generic code (no special handling needed) or positive to skip
   * generic parsing (needed special handling which was done in the hook already)
   * input_mapped shall return negative to inform the layer that this usage
   * should not be considered for further processing or zero to notify that
   * no processing was performed and should be done in a generic manner
   * Both these functions may be NULL which means the same behavior as returning
   * zero from them.
85cdaf524   Jiri Slaby   HID: make a bus f...
654
655
656
657
   */
  struct hid_driver {
  	char *name;
  	const struct hid_device_id *id_table;
3a6f82f7a   Jiri Slaby   HID: add dynids f...
658
659
  	struct list_head dyn_list;
  	spinlock_t dyn_lock;
85cdaf524   Jiri Slaby   HID: make a bus f...
660
661
662
663
664
665
666
667
668
  	int (*probe)(struct hid_device *dev, const struct hid_device_id *id);
  	void (*remove)(struct hid_device *dev);
  
  	const struct hid_report_id *report_table;
  	int (*raw_event)(struct hid_device *hdev, struct hid_report *report,
  			u8 *data, int size);
  	const struct hid_usage_id *usage_table;
  	int (*event)(struct hid_device *hdev, struct hid_field *field,
  			struct hid_usage *usage, __s32 value);
6d85d037d   Benjamin Tissoires   HID: core: add "r...
669
  	void (*report)(struct hid_device *hdev, struct hid_report *report);
c500c9714   Jiri Slaby   HID: hid, make pa...
670

73e4008dd   Nikolai Kondrashov   HID: allow resizi...
671
672
  	__u8 *(*report_fixup)(struct hid_device *hdev, __u8 *buf,
  			unsigned int *size);
c500c9714   Jiri Slaby   HID: hid, make pa...
673
674
675
676
677
678
679
  
  	int (*input_mapping)(struct hid_device *hdev,
  			struct hid_input *hidinput, struct hid_field *field,
  			struct hid_usage *usage, unsigned long **bit, int *max);
  	int (*input_mapped)(struct hid_device *hdev,
  			struct hid_input *hidinput, struct hid_field *field,
  			struct hid_usage *usage, unsigned long **bit, int *max);
9154301a4   Dmitry Torokhov   HID: hid-input: a...
680
681
  	int (*input_configured)(struct hid_device *hdev,
  				struct hid_input *hidinput);
0d2689c0f   Benjamin Tissoires   HID: add feature_...
682
  	void (*feature_mapping)(struct hid_device *hdev,
f635bd11c   Henrik Rydberg   HID: Do not creat...
683
  			struct hid_field *field,
0d2689c0f   Benjamin Tissoires   HID: add feature_...
684
  			struct hid_usage *usage);
6a740aa4f   Bruno Prémont   HID: add suspend/...
685
686
687
688
689
  #ifdef CONFIG_PM
  	int (*suspend)(struct hid_device *hdev, pm_message_t message);
  	int (*resume)(struct hid_device *hdev);
  	int (*reset_resume)(struct hid_device *hdev);
  #endif
85cdaf524   Jiri Slaby   HID: make a bus f...
690
691
692
  /* private: */
  	struct device_driver driver;
  };
ba91a9671   Geliang Tang   HID: add a new he...
693
694
  #define to_hid_driver(pdrv) \
  	container_of(pdrv, struct hid_driver, driver)
c500c9714   Jiri Slaby   HID: hid, make pa...
695
696
697
698
699
700
  /**
   * hid_ll_driver - low level driver callbacks
   * @start: called on probe to start the device
   * @stop: called on remove
   * @open: called by input layer on open
   * @close: called by input layer on close
c500c9714   Jiri Slaby   HID: hid, make pa...
701
702
   * @parse: this method is called only once to parse the device data,
   *	   shouldn't allocate anything to not leak memory
e90a6df80   Henrik Rydberg   HID: Extend the i...
703
   * @request: send report request to device (e.g. feature report)
3373443be   Henrik Rydberg   HID: Extend the i...
704
   * @wait: wait for buffered io to complete (send/recv reports)
b69d65367   Benjamin Tissoires   HID: add inliners...
705
706
   * @raw_request: send raw report request to device (e.g. feature report)
   * @output_report: send output report to device
9684819b5   Benjamin Tissoires   HID: ll_driver: E...
707
   * @idle: send idle request to device
c500c9714   Jiri Slaby   HID: hid, make pa...
708
709
710
711
712
713
714
   */
  struct hid_ll_driver {
  	int (*start)(struct hid_device *hdev);
  	void (*stop)(struct hid_device *hdev);
  
  	int (*open)(struct hid_device *hdev);
  	void (*close)(struct hid_device *hdev);
0361a28d3   Oliver Neukum   HID: autosuspend ...
715
  	int (*power)(struct hid_device *hdev, int level);
c500c9714   Jiri Slaby   HID: hid, make pa...
716
  	int (*parse)(struct hid_device *hdev);
e90a6df80   Henrik Rydberg   HID: Extend the i...
717
718
719
  
  	void (*request)(struct hid_device *hdev,
  			struct hid_report *report, int reqtype);
3373443be   Henrik Rydberg   HID: Extend the i...
720
  	int (*wait)(struct hid_device *hdev);
cd4dc0821   Frank Praznik   HID: Add transpor...
721
722
723
724
725
726
727
  	int (*raw_request) (struct hid_device *hdev, unsigned char reportnum,
  			    __u8 *buf, size_t len, unsigned char rtype,
  			    int reqtype);
  
  	int (*output_report) (struct hid_device *hdev, __u8 *buf, size_t len);
  
  	int (*idle)(struct hid_device *hdev, int report, int idle, int reqtype);
c500c9714   Jiri Slaby   HID: hid, make pa...
728
  };
0361a28d3   Oliver Neukum   HID: autosuspend ...
729
730
  #define	PM_HINT_FULLON	1<<5
  #define PM_HINT_NORMAL	1<<1
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
731
732
  /* Applications from HID Usage Tables 4/8/99 Version 1.1 */
  /* We ignore a few input applications that are not widely used */
8b0e58a70   Stephane Chatty   HID: let hid-inpu...
733
  #define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || (a == 0x00010080) || (a == 0x000c0001) || ((a >= 0x000d0002) && (a <= 0x000d0006)))
229695e51   Jiri Kosina   [PATCH] Generic H...
734
735
  
  /* HID core API */
58037eb96   Jiri Kosina   HID: make debuggi...
736

58037eb96   Jiri Kosina   HID: make debuggi...
737
  extern int hid_debug;
58037eb96   Jiri Kosina   HID: make debuggi...
738

4529eefad   Lamarque V. Souza   HID: hidp: fallba...
739
  extern bool hid_ignore(struct hid_device *);
85cdaf524   Jiri Slaby   HID: make a bus f...
740
741
742
743
744
  extern int hid_add_device(struct hid_device *);
  extern void hid_destroy_device(struct hid_device *);
  
  extern int __must_check __hid_register_driver(struct hid_driver *,
  		struct module *, const char *mod_name);
eb5589a8f   Paul Gortmaker   include: convert ...
745
746
747
748
  
  /* use a define to avoid include chaining to get THIS_MODULE & friends */
  #define hid_register_driver(driver) \
  	__hid_register_driver(driver, THIS_MODULE, KBUILD_MODNAME)
85cdaf524   Jiri Slaby   HID: make a bus f...
749
  extern void hid_unregister_driver(struct hid_driver *);
4d02c58eb   H Hartley Sweeten   HID: introduce he...
750
751
752
753
754
755
756
757
758
759
760
  /**
   * module_hid_driver() - Helper macro for registering a HID driver
   * @__hid_driver: hid_driver struct
   *
   * Helper macro for HID drivers which do not do anything special in module
   * init/exit. This eliminates a lot of boilerplate. Each module may only
   * use this macro once, and calling it replaces module_init() and module_exit()
   */
  #define module_hid_driver(__hid_driver) \
  	module_driver(__hid_driver, hid_register_driver, \
  		      hid_unregister_driver)
7d12e780e   David Howells   IRQ: Maintain reg...
761
  extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
762
  extern void hidinput_report_event(struct hid_device *hid, struct hid_report *report);
93c10132a   Jiri Slaby   HID: move connect...
763
  extern int hidinput_connect(struct hid_device *hid, unsigned int force);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
764
  extern void hidinput_disconnect(struct hid_device *);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
765

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
766
  int hid_set_field(struct hid_field *, unsigned, __s32);
aa8de2f03   Jiri Kosina   [PATCH] Generic H...
767
  int hid_input_report(struct hid_device *, int type, u8 *, int, int);
dde5845a5   Jiri Kosina   [PATCH] Generic H...
768
  int hidinput_find_field(struct hid_device *hid, unsigned int type, unsigned int code, struct hid_field **field);
4371ea820   Daniel Kurtz   HID: usbhid: defe...
769
770
  struct hid_field *hidinput_get_led_field(struct hid_device *hid);
  unsigned int hidinput_count_leds(struct hid_device *hid);
37cf6e6fc   Benjamin Tissoires   HID: export hidin...
771
  __s32 hidinput_calc_abs_res(const struct hid_field *field, __u16 code);
dde5845a5   Jiri Kosina   [PATCH] Generic H...
772
  void hid_output_report(struct hid_report *report, __u8 *data);
4fa5a7f76   Benjamin Tissoires   HID: core: implem...
773
  void __hid_request(struct hid_device *hid, struct hid_report *rep, int reqtype);
27ce40503   Jiri Kosina   HID: fix data acc...
774
  u8 *hid_alloc_report_buf(struct hid_report *report, gfp_t flags);
85cdaf524   Jiri Slaby   HID: make a bus f...
775
  struct hid_device *hid_allocate_device(void);
90a006abf   Michael Poole   HID: Export hid_r...
776
  struct hid_report *hid_register_report(struct hid_device *device, unsigned type, unsigned id);
85cdaf524   Jiri Slaby   HID: make a bus f...
777
  int hid_parse_report(struct hid_device *hid, __u8 *start, unsigned size);
331415ff1   Kees Cook   HID: provide a he...
778
779
780
781
  struct hid_report *hid_validate_values(struct hid_device *hid,
  				       unsigned int type, unsigned int id,
  				       unsigned int field_index,
  				       unsigned int report_counts);
a7197c2e4   Henrik Rydberg   HID: Handle drive...
782
  int hid_open_report(struct hid_device *device);
0361a28d3   Oliver Neukum   HID: autosuspend ...
783
  int hid_check_keys_pressed(struct hid_device *hid);
93c10132a   Jiri Slaby   HID: move connect...
784
  int hid_connect(struct hid_device *hid, unsigned int connect_mask);
c4c259bcc   Jiri Kosina   HID: consolidate ...
785
  void hid_disconnect(struct hid_device *hid);
bbc21cfd5   Jeremy Fitzhardinge   hid-input/battery...
786
787
  const struct hid_device_id *hid_match_id(struct hid_device *hdev,
  					 const struct hid_device_id *id);
774638386   Benjamin Tissoires   HID: fix unit exp...
788
  s32 hid_snto32(__u32 value, unsigned n);
04fba7864   Goffredo Baroncelli   HID: Export hid_f...
789
790
  __u32 hid_field_extract(const struct hid_device *hid, __u8 *report,
  		     unsigned offset, unsigned n);
85cdaf524   Jiri Slaby   HID: make a bus f...
791

c500c9714   Jiri Slaby   HID: hid, make pa...
792
  /**
c849a6143   Andrew de los Reyes   HID: Separate str...
793
794
795
796
797
798
799
800
801
802
   * hid_device_io_start - enable HID input during probe, remove
   *
   * @hid - the device
   *
   * This should only be called during probe or remove and only be
   * called by the thread calling probe or remove. It will allow
   * incoming packets to be delivered to the driver.
   */
  static inline void hid_device_io_start(struct hid_device *hid) {
  	if (hid->io_started) {
6c3f70ac7   Colin Ian King   HID: add missing ...
803
804
  		dev_warn(&hid->dev, "io already started
  ");
c849a6143   Andrew de los Reyes   HID: Separate str...
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
  		return;
  	}
  	hid->io_started = true;
  	up(&hid->driver_input_lock);
  }
  
  /**
   * hid_device_io_stop - disable HID input during probe, remove
   *
   * @hid - the device
   *
   * Should only be called after hid_device_io_start. It will prevent
   * incoming packets from going to the driver for the duration of
   * probe, remove. If called during probe, packets will still go to the
   * driver after probe is complete. This function should only be called
   * by the thread calling probe or remove.
   */
  static inline void hid_device_io_stop(struct hid_device *hid) {
  	if (!hid->io_started) {
6c3f70ac7   Colin Ian King   HID: add missing ...
824
825
  		dev_warn(&hid->dev, "io already stopped
  ");
c849a6143   Andrew de los Reyes   HID: Separate str...
826
827
828
829
830
831
832
  		return;
  	}
  	hid->io_started = false;
  	down(&hid->driver_input_lock);
  }
  
  /**
022e8c4d0   Jiri Slaby   HID: move usage i...
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
   * hid_map_usage - map usage input bits
   *
   * @hidinput: hidinput which we are interested in
   * @usage: usage to fill in
   * @bit: pointer to input->{}bit (out parameter)
   * @max: maximal valid usage->code to consider later (out parameter)
   * @type: input event type (EV_KEY, EV_REL, ...)
   * @c: code which corresponds to this usage and type
   */
  static inline void hid_map_usage(struct hid_input *hidinput,
  		struct hid_usage *usage, unsigned long **bit, int *max,
  		__u8 type, __u16 c)
  {
  	struct input_dev *input = hidinput->input;
  
  	usage->type = type;
  	usage->code = c;
  
  	switch (type) {
  	case EV_ABS:
  		*bit = input->absbit;
  		*max = ABS_MAX;
  		break;
  	case EV_REL:
  		*bit = input->relbit;
  		*max = REL_MAX;
  		break;
  	case EV_KEY:
  		*bit = input->keybit;
  		*max = KEY_MAX;
  		break;
  	case EV_LED:
  		*bit = input->ledbit;
  		*max = LED_MAX;
  		break;
  	}
  }
  
  /**
   * hid_map_usage_clear - map usage input bits and clear the input bit
   *
   * The same as hid_map_usage, except the @c bit is also cleared in supported
   * bits (@bit).
   */
  static inline void hid_map_usage_clear(struct hid_input *hidinput,
  		struct hid_usage *usage, unsigned long **bit, int *max,
  		__u8 type, __u16 c)
  {
  	hid_map_usage(hidinput, usage, bit, max, type, c);
  	clear_bit(c, *bit);
  }
  
  /**
c500c9714   Jiri Slaby   HID: hid, make pa...
886
887
888
889
890
891
892
893
894
895
   * hid_parse - parse HW reports
   *
   * @hdev: hid device
   *
   * Call this from probe after you set up the device (if needed). Your
   * report_fixup will be called (if non-NULL) after reading raw report from
   * device before passing it to hid layer for real parsing.
   */
  static inline int __must_check hid_parse(struct hid_device *hdev)
  {
a7197c2e4   Henrik Rydberg   HID: Handle drive...
896
  	return hid_open_report(hdev);
c500c9714   Jiri Slaby   HID: hid, make pa...
897
898
899
900
901
902
  }
  
  /**
   * hid_hw_start - start underlaying HW
   *
   * @hdev: hid device
93c10132a   Jiri Slaby   HID: move connect...
903
   * @connect_mask: which outputs to connect, see HID_CONNECT_*
c500c9714   Jiri Slaby   HID: hid, make pa...
904
905
906
   *
   * Call this in probe function *after* hid_parse. This will setup HW buffers
   * and start the device (if not deffered to device open). hid_hw_stop must be
25985edce   Lucas De Marchi   Fix common misspe...
907
   * called if this was successful.
c500c9714   Jiri Slaby   HID: hid, make pa...
908
   */
93c10132a   Jiri Slaby   HID: move connect...
909
910
  static inline int __must_check hid_hw_start(struct hid_device *hdev,
  		unsigned int connect_mask)
c500c9714   Jiri Slaby   HID: hid, make pa...
911
  {
93c10132a   Jiri Slaby   HID: move connect...
912
913
914
915
916
917
918
  	int ret = hdev->ll_driver->start(hdev);
  	if (ret || !connect_mask)
  		return ret;
  	ret = hid_connect(hdev, connect_mask);
  	if (ret)
  		hdev->ll_driver->stop(hdev);
  	return ret;
c500c9714   Jiri Slaby   HID: hid, make pa...
919
920
921
922
923
924
925
926
927
928
929
930
  }
  
  /**
   * hid_hw_stop - stop underlaying HW
   *
   * @hdev: hid device
   *
   * This is usually called from remove function or from probe when something
   * failed and hid_hw_start was called already.
   */
  static inline void hid_hw_stop(struct hid_device *hdev)
  {
c4c259bcc   Jiri Kosina   HID: consolidate ...
931
  	hid_disconnect(hdev);
c500c9714   Jiri Slaby   HID: hid, make pa...
932
933
  	hdev->ll_driver->stop(hdev);
  }
5bea7660b   Dmitry Torokhov   HID: add hid_hw_o...
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
  /**
   * hid_hw_open - signal underlaying HW to start delivering events
   *
   * @hdev: hid device
   *
   * Tell underlying HW to start delivering events from the device.
   * This function should be called sometime after successful call
   * to hid_hiw_start().
   */
  static inline int __must_check hid_hw_open(struct hid_device *hdev)
  {
  	return hdev->ll_driver->open(hdev);
  }
  
  /**
   * hid_hw_close - signal underlaying HW to stop delivering events
   *
   * @hdev: hid device
   *
   * This function indicates that we are not interested in the events
   * from this device anymore. Delivery of events may or may not stop,
   * depending on the number of users still outstanding.
   */
  static inline void hid_hw_close(struct hid_device *hdev)
  {
  	hdev->ll_driver->close(hdev);
  }
  
  /**
   * hid_hw_power - requests underlying HW to go into given power mode
   *
   * @hdev: hid device
   * @level: requested power level (one of %PM_HINT_* defines)
   *
   * This function requests underlying hardware to enter requested power
   * mode.
   */
  
  static inline int hid_hw_power(struct hid_device *hdev, int level)
  {
  	return hdev->ll_driver->power ? hdev->ll_driver->power(hdev, level) : 0;
  }
e90a6df80   Henrik Rydberg   HID: Extend the i...
976
977
978
979
980
981
982
983
984
985
986
987
  
  /**
   * hid_hw_request - send report request to device
   *
   * @hdev: hid device
   * @report: report to send
   * @reqtype: hid request type
   */
  static inline void hid_hw_request(struct hid_device *hdev,
  				  struct hid_report *report, int reqtype)
  {
  	if (hdev->ll_driver->request)
4fa5a7f76   Benjamin Tissoires   HID: core: implem...
988
989
990
  		return hdev->ll_driver->request(hdev, report, reqtype);
  
  	__hid_request(hdev, report, reqtype);
e90a6df80   Henrik Rydberg   HID: Extend the i...
991
  }
3373443be   Henrik Rydberg   HID: Extend the i...
992
  /**
b69d65367   Benjamin Tissoires   HID: add inliners...
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
   * hid_hw_raw_request - send report request to device
   *
   * @hdev: hid device
   * @reportnum: report ID
   * @buf: in/out data to transfer
   * @len: length of buf
   * @rtype: HID report type
   * @reqtype: HID_REQ_GET_REPORT or HID_REQ_SET_REPORT
   *
   * @return: count of data transfered, negative if error
   *
   * Same behavior as hid_hw_request, but with raw buffers instead.
   */
  static inline int hid_hw_raw_request(struct hid_device *hdev,
  				  unsigned char reportnum, __u8 *buf,
  				  size_t len, unsigned char rtype, int reqtype)
  {
531825174   Benjamin Tissoires   HID: core: check ...
1010
1011
  	if (len < 1 || len > HID_MAX_BUFFER_SIZE || !buf)
  		return -EINVAL;
3c86726cf   Benjamin Tissoires   HID: make .raw_re...
1012
  	return hdev->ll_driver->raw_request(hdev, reportnum, buf, len,
b69d65367   Benjamin Tissoires   HID: add inliners...
1013
  						    rtype, reqtype);
b69d65367   Benjamin Tissoires   HID: add inliners...
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
  }
  
  /**
   * hid_hw_output_report - send output report to device
   *
   * @hdev: hid device
   * @buf: raw data to transfer
   * @len: length of buf
   *
   * @return: count of data transfered, negative if error
   */
  static inline int hid_hw_output_report(struct hid_device *hdev, __u8 *buf,
  					size_t len)
  {
531825174   Benjamin Tissoires   HID: core: check ...
1028
1029
  	if (len < 1 || len > HID_MAX_BUFFER_SIZE || !buf)
  		return -EINVAL;
b69d65367   Benjamin Tissoires   HID: add inliners...
1030
1031
1032
1033
1034
1035
1036
  	if (hdev->ll_driver->output_report)
  		return hdev->ll_driver->output_report(hdev, buf, len);
  
  	return -ENOSYS;
  }
  
  /**
9684819b5   Benjamin Tissoires   HID: ll_driver: E...
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
   * hid_hw_idle - send idle request to device
   *
   * @hdev: hid device
   * @report: report to control
   * @idle: idle state
   * @reqtype: hid request type
   */
  static inline int hid_hw_idle(struct hid_device *hdev, int report, int idle,
  		int reqtype)
  {
  	if (hdev->ll_driver->idle)
  		return hdev->ll_driver->idle(hdev, report, idle, reqtype);
  
  	return 0;
  }
  
  /**
3373443be   Henrik Rydberg   HID: Extend the i...
1054
1055
1056
1057
1058
1059
1060
1061
1062
   * hid_hw_wait - wait for buffered io to complete
   *
   * @hdev: hid device
   */
  static inline void hid_hw_wait(struct hid_device *hdev)
  {
  	if (hdev->ll_driver->wait)
  		hdev->ll_driver->wait(hdev);
  }
dabb05c66   Mathieu Magnaudet   HID: make hid_rep...
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
  /**
   * hid_report_len - calculate the report length
   *
   * @report: the report we want to know the length
   */
  static inline int hid_report_len(struct hid_report *report)
  {
  	/* equivalent to DIV_ROUND_UP(report->size, 8) + !!(report->id > 0) */
  	return ((report->size - 1) >> 3) + 1 + (report->id > 0);
  }
b6787242f   Jiri Kosina   HID: hidraw: add ...
1073
  int hid_report_raw_event(struct hid_device *hid, int type, u8 *data, int size,
85cdaf524   Jiri Slaby   HID: make a bus f...
1074
  		int interrupt);
876b9276b   Paul Walmsley   USB HID: add 'qui...
1075
  /* HID quirks API */
2eb5dc30e   Paul Walmsley   USB HID: encapsul...
1076
  u32 usbhid_lookup_quirk(const u16 idVendor, const u16 idProduct);
876b9276b   Paul Walmsley   USB HID: add 'qui...
1077
1078
  int usbhid_quirks_init(char **quirks_param);
  void usbhid_quirks_exit(void);
2eb5dc30e   Paul Walmsley   USB HID: encapsul...
1079

224ee88fe   Anssi Hannula   Input: add force ...
1080
1081
1082
  #ifdef CONFIG_HID_PID
  int hid_pidff_init(struct hid_device *hid);
  #else
76483cf4d   Jiri Slaby   HID: remove hid-ff
1083
  #define hid_pidff_init NULL
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1084
  #endif
58037eb96   Jiri Kosina   HID: make debuggi...
1085

4291ee305   Joe Perches   HID: Add and use ...
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
  #define dbg_hid(format, arg...)						\
  do {									\
  	if (hid_debug)							\
  		printk(KERN_DEBUG "%s: " format, __FILE__, ##arg);	\
  } while (0)
  
  #define hid_printk(level, hid, fmt, arg...)		\
  	dev_printk(level, &(hid)->dev, fmt, ##arg)
  #define hid_emerg(hid, fmt, arg...)			\
  	dev_emerg(&(hid)->dev, fmt, ##arg)
  #define hid_crit(hid, fmt, arg...)			\
  	dev_crit(&(hid)->dev, fmt, ##arg)
  #define hid_alert(hid, fmt, arg...)			\
  	dev_alert(&(hid)->dev, fmt, ##arg)
  #define hid_err(hid, fmt, arg...)			\
  	dev_err(&(hid)->dev, fmt, ##arg)
  #define hid_notice(hid, fmt, arg...)			\
  	dev_notice(&(hid)->dev, fmt, ##arg)
  #define hid_warn(hid, fmt, arg...)			\
  	dev_warn(&(hid)->dev, fmt, ##arg)
  #define hid_info(hid, fmt, arg...)			\
  	dev_info(&(hid)->dev, fmt, ##arg)
  #define hid_dbg(hid, fmt, arg...)			\
  	dev_dbg(&(hid)->dev, fmt, ##arg)
57d292bd7   Jiri Kosina   HID: fix HIDIOCGR...
1110
  #endif