Commit | Line | Data |
---|---|---|
2eb5dc30 PW |
1 | /* |
2 | * USB HID quirks support for Linux | |
3 | * | |
4 | * Copyright (c) 1999 Andreas Gal | |
5 | * Copyright (c) 2000-2005 Vojtech Pavlik <vojtech@suse.cz> | |
6 | * Copyright (c) 2005 Michael Haboustak <mike-@cinci.rr.com> for Concept2, Inc | |
7 | * Copyright (c) 2006-2007 Jiri Kosina | |
8 | * Copyright (c) 2007 Paul Walmsley | |
9 | */ | |
10 | ||
11 | /* | |
12 | * This program is free software; you can redistribute it and/or modify it | |
13 | * under the terms of the GNU General Public License as published by the Free | |
14 | * Software Foundation; either version 2 of the License, or (at your option) | |
15 | * any later version. | |
16 | */ | |
17 | ||
18 | #include <linux/hid.h> | |
19 | ||
20 | #define USB_VENDOR_ID_A4TECH 0x09da | |
21 | #define USB_DEVICE_ID_A4TECH_WCP32PU 0x0006 | |
c80e5ffa | 22 | #define USB_DEVICE_ID_A4TECH_X5_005D 0x000a |
2eb5dc30 PW |
23 | |
24 | #define USB_VENDOR_ID_AASHIMA 0x06d6 | |
25 | #define USB_DEVICE_ID_AASHIMA_GAMEPAD 0x0025 | |
26 | #define USB_DEVICE_ID_AASHIMA_PREDATOR 0x0026 | |
27 | ||
28 | #define USB_VENDOR_ID_ACECAD 0x0460 | |
29 | #define USB_DEVICE_ID_ACECAD_FLAIR 0x0004 | |
30 | #define USB_DEVICE_ID_ACECAD_302 0x0008 | |
31 | ||
32 | #define USB_VENDOR_ID_AIPTEK 0x08ca | |
33 | #define USB_DEVICE_ID_AIPTEK_01 0x0001 | |
34 | #define USB_DEVICE_ID_AIPTEK_10 0x0010 | |
35 | #define USB_DEVICE_ID_AIPTEK_20 0x0020 | |
36 | #define USB_DEVICE_ID_AIPTEK_21 0x0021 | |
37 | #define USB_DEVICE_ID_AIPTEK_22 0x0022 | |
38 | #define USB_DEVICE_ID_AIPTEK_23 0x0023 | |
39 | #define USB_DEVICE_ID_AIPTEK_24 0x0024 | |
40 | ||
41 | #define USB_VENDOR_ID_AIRCABLE 0x16CA | |
42 | #define USB_DEVICE_ID_AIRCABLE1 0x1502 | |
43 | ||
44 | #define USB_VENDOR_ID_ALCOR 0x058f | |
45 | #define USB_DEVICE_ID_ALCOR_USBRS232 0x9720 | |
46 | ||
47 | #define USB_VENDOR_ID_ALPS 0x0433 | |
48 | #define USB_DEVICE_ID_IBM_GAMEPAD 0x1101 | |
49 | ||
50 | #define USB_VENDOR_ID_APPLE 0x05ac | |
51 | #define USB_DEVICE_ID_APPLE_MIGHTYMOUSE 0x0304 | |
52 | #define USB_DEVICE_ID_APPLE_FOUNTAIN_ANSI 0x020e | |
53 | #define USB_DEVICE_ID_APPLE_FOUNTAIN_ISO 0x020f | |
54 | #define USB_DEVICE_ID_APPLE_GEYSER_ANSI 0x0214 | |
55 | #define USB_DEVICE_ID_APPLE_GEYSER_ISO 0x0215 | |
56 | #define USB_DEVICE_ID_APPLE_GEYSER_JIS 0x0216 | |
57 | #define USB_DEVICE_ID_APPLE_GEYSER3_ANSI 0x0217 | |
58 | #define USB_DEVICE_ID_APPLE_GEYSER3_ISO 0x0218 | |
59 | #define USB_DEVICE_ID_APPLE_GEYSER3_JIS 0x0219 | |
60 | #define USB_DEVICE_ID_APPLE_GEYSER4_ANSI 0x021a | |
61 | #define USB_DEVICE_ID_APPLE_GEYSER4_ISO 0x021b | |
62 | #define USB_DEVICE_ID_APPLE_GEYSER4_JIS 0x021c | |
a45d82d1 MD |
63 | #define USB_DEVICE_ID_APPLE_ALU_ANSI 0x0220 |
64 | #define USB_DEVICE_ID_APPLE_ALU_ISO 0x0221 | |
65 | #define USB_DEVICE_ID_APPLE_ALU_JIS 0x0222 | |
2eb5dc30 PW |
66 | #define USB_DEVICE_ID_APPLE_FOUNTAIN_TP_ONLY 0x030a |
67 | #define USB_DEVICE_ID_APPLE_GEYSER1_TP_ONLY 0x030b | |
0ce91cf9 | 68 | #define USB_DEVICE_ID_APPLE_IRCONTROL4 0x8242 |
2eb5dc30 | 69 | |
04a9b7ff CL |
70 | #define USB_VENDOR_ID_ASUS 0x0b05 |
71 | #define USB_DEVICE_ID_ASUS_LCM 0x1726 | |
72 | ||
2eb5dc30 PW |
73 | #define USB_VENDOR_ID_ATEN 0x0557 |
74 | #define USB_DEVICE_ID_ATEN_UC100KM 0x2004 | |
75 | #define USB_DEVICE_ID_ATEN_CS124U 0x2202 | |
76 | #define USB_DEVICE_ID_ATEN_2PORTKVM 0x2204 | |
77 | #define USB_DEVICE_ID_ATEN_4PORTKVM 0x2205 | |
78 | #define USB_DEVICE_ID_ATEN_4PORTKVMC 0x2208 | |
79 | ||
80 | #define USB_VENDOR_ID_BELKIN 0x050d | |
81 | #define USB_DEVICE_ID_FLIP_KVM 0x3201 | |
82 | ||
83 | #define USB_VENDOR_ID_BERKSHIRE 0x0c98 | |
84 | #define USB_DEVICE_ID_BERKSHIRE_PCWD 0x1140 | |
85 | ||
86 | #define USB_VENDOR_ID_CHERRY 0x046a | |
87 | #define USB_DEVICE_ID_CHERRY_CYMOTION 0x0023 | |
88 | ||
89 | #define USB_VENDOR_ID_CHIC 0x05fe | |
90 | #define USB_DEVICE_ID_CHIC_GAMEPAD 0x0014 | |
91 | ||
92 | #define USB_VENDOR_ID_CIDC 0x1677 | |
93 | ||
c4025ade AH |
94 | #define USB_VENDOR_ID_CMEDIA 0x0d8c |
95 | #define USB_DEVICE_ID_CM109 0x000e | |
96 | ||
2eb5dc30 PW |
97 | #define USB_VENDOR_ID_CODEMERCS 0x07c0 |
98 | #define USB_DEVICE_ID_CODEMERCS_IOW_FIRST 0x1500 | |
99 | #define USB_DEVICE_ID_CODEMERCS_IOW_LAST 0x15ff | |
100 | ||
101 | #define USB_VENDOR_ID_CYPRESS 0x04b4 | |
102 | #define USB_DEVICE_ID_CYPRESS_MOUSE 0x0001 | |
103 | #define USB_DEVICE_ID_CYPRESS_HIDCOM 0x5500 | |
104 | #define USB_DEVICE_ID_CYPRESS_ULTRAMOUSE 0x7417 | |
66da8769 JK |
105 | #define USB_DEVICE_ID_CYPRESS_BARCODE_1 0xde61 |
106 | #define USB_DEVICE_ID_CYPRESS_BARCODE_2 0xde64 | |
2eb5dc30 PW |
107 | |
108 | #define USB_VENDOR_ID_DELL 0x413c | |
109 | #define USB_DEVICE_ID_DELL_W7658 0x2005 | |
110 | ||
111 | #define USB_VENDOR_ID_DELORME 0x1163 | |
112 | #define USB_DEVICE_ID_DELORME_EARTHMATE 0x0100 | |
113 | #define USB_DEVICE_ID_DELORME_EM_LT20 0x0200 | |
114 | ||
d500d116 MC |
115 | #define USB_VENDOR_ID_ELO 0x04E7 |
116 | #define USB_DEVICE_ID_ELO_TS2700 0x0020 | |
117 | ||
2eb5dc30 PW |
118 | #define USB_VENDOR_ID_ESSENTIAL_REALITY 0x0d7f |
119 | #define USB_DEVICE_ID_ESSENTIAL_REALITY_P5 0x0100 | |
120 | ||
1b3ebe93 JE |
121 | #define USB_VENDOR_ID_GAMERON 0x0810 |
122 | #define USB_DEVICE_ID_GAMERON_DUAL_PSX_ADAPTOR 0x0001 | |
123 | ||
44694359 IF |
124 | #define USB_VENDOR_ID_GENERAL_TOUCH 0x0dfc |
125 | ||
2eb5dc30 PW |
126 | #define USB_VENDOR_ID_GLAB 0x06c2 |
127 | #define USB_DEVICE_ID_4_PHIDGETSERVO_30 0x0038 | |
128 | #define USB_DEVICE_ID_1_PHIDGETSERVO_30 0x0039 | |
129 | #define USB_DEVICE_ID_0_0_4_IF_KIT 0x0040 | |
130 | #define USB_DEVICE_ID_0_16_16_IF_KIT 0x0044 | |
131 | #define USB_DEVICE_ID_8_8_8_IF_KIT 0x0045 | |
132 | #define USB_DEVICE_ID_0_8_7_IF_KIT 0x0051 | |
133 | #define USB_DEVICE_ID_0_8_8_IF_KIT 0x0053 | |
134 | #define USB_DEVICE_ID_PHIDGET_MOTORCONTROL 0x0058 | |
135 | ||
df7bded7 JJ |
136 | #define USB_VENDOR_ID_GOTOP 0x08f2 |
137 | #define USB_DEVICE_ID_SUPER_Q2 0x007f | |
138 | #define USB_DEVICE_ID_GOGOPEN 0x00ce | |
139 | #define USB_DEVICE_ID_PENPOWER 0x00f4 | |
140 | ||
2eb5dc30 PW |
141 | #define USB_VENDOR_ID_GRIFFIN 0x077d |
142 | #define USB_DEVICE_ID_POWERMATE 0x0410 | |
143 | #define USB_DEVICE_ID_SOUNDKNOB 0x04AA | |
144 | ||
145 | #define USB_VENDOR_ID_GTCO 0x078c | |
146 | #define USB_DEVICE_ID_GTCO_90 0x0090 | |
147 | #define USB_DEVICE_ID_GTCO_100 0x0100 | |
148 | #define USB_DEVICE_ID_GTCO_101 0x0101 | |
149 | #define USB_DEVICE_ID_GTCO_103 0x0103 | |
150 | #define USB_DEVICE_ID_GTCO_104 0x0104 | |
151 | #define USB_DEVICE_ID_GTCO_105 0x0105 | |
152 | #define USB_DEVICE_ID_GTCO_106 0x0106 | |
153 | #define USB_DEVICE_ID_GTCO_107 0x0107 | |
154 | #define USB_DEVICE_ID_GTCO_108 0x0108 | |
155 | #define USB_DEVICE_ID_GTCO_200 0x0200 | |
156 | #define USB_DEVICE_ID_GTCO_201 0x0201 | |
157 | #define USB_DEVICE_ID_GTCO_202 0x0202 | |
158 | #define USB_DEVICE_ID_GTCO_203 0x0203 | |
159 | #define USB_DEVICE_ID_GTCO_204 0x0204 | |
160 | #define USB_DEVICE_ID_GTCO_205 0x0205 | |
161 | #define USB_DEVICE_ID_GTCO_206 0x0206 | |
162 | #define USB_DEVICE_ID_GTCO_207 0x0207 | |
163 | #define USB_DEVICE_ID_GTCO_300 0x0300 | |
164 | #define USB_DEVICE_ID_GTCO_301 0x0301 | |
165 | #define USB_DEVICE_ID_GTCO_302 0x0302 | |
166 | #define USB_DEVICE_ID_GTCO_303 0x0303 | |
167 | #define USB_DEVICE_ID_GTCO_304 0x0304 | |
168 | #define USB_DEVICE_ID_GTCO_305 0x0305 | |
169 | #define USB_DEVICE_ID_GTCO_306 0x0306 | |
170 | #define USB_DEVICE_ID_GTCO_307 0x0307 | |
171 | #define USB_DEVICE_ID_GTCO_308 0x0308 | |
172 | #define USB_DEVICE_ID_GTCO_309 0x0309 | |
173 | #define USB_DEVICE_ID_GTCO_400 0x0400 | |
174 | #define USB_DEVICE_ID_GTCO_401 0x0401 | |
175 | #define USB_DEVICE_ID_GTCO_402 0x0402 | |
176 | #define USB_DEVICE_ID_GTCO_403 0x0403 | |
177 | #define USB_DEVICE_ID_GTCO_404 0x0404 | |
178 | #define USB_DEVICE_ID_GTCO_405 0x0405 | |
179 | #define USB_DEVICE_ID_GTCO_500 0x0500 | |
180 | #define USB_DEVICE_ID_GTCO_501 0x0501 | |
181 | #define USB_DEVICE_ID_GTCO_502 0x0502 | |
182 | #define USB_DEVICE_ID_GTCO_503 0x0503 | |
183 | #define USB_DEVICE_ID_GTCO_504 0x0504 | |
184 | #define USB_DEVICE_ID_GTCO_1000 0x1000 | |
185 | #define USB_DEVICE_ID_GTCO_1001 0x1001 | |
186 | #define USB_DEVICE_ID_GTCO_1002 0x1002 | |
187 | #define USB_DEVICE_ID_GTCO_1003 0x1003 | |
188 | #define USB_DEVICE_ID_GTCO_1004 0x1004 | |
189 | #define USB_DEVICE_ID_GTCO_1005 0x1005 | |
190 | #define USB_DEVICE_ID_GTCO_1006 0x1006 | |
191 | ||
192 | #define USB_VENDOR_ID_HAPP 0x078b | |
193 | #define USB_DEVICE_ID_UGCI_DRIVING 0x0010 | |
194 | #define USB_DEVICE_ID_UGCI_FLYING 0x0020 | |
195 | #define USB_DEVICE_ID_UGCI_FIGHTING 0x0030 | |
196 | ||
197 | #define USB_VENDOR_ID_IMATION 0x0718 | |
198 | #define USB_DEVICE_ID_DISC_STAKKA 0xd000 | |
199 | ||
200 | #define USB_VENDOR_ID_KBGEAR 0x084e | |
201 | #define USB_DEVICE_ID_KBGEAR_JAMSTUDIO 0x1001 | |
202 | ||
203 | #define USB_VENDOR_ID_LD 0x0f11 | |
204 | #define USB_DEVICE_ID_LD_CASSY 0x1000 | |
205 | #define USB_DEVICE_ID_LD_POCKETCASSY 0x1010 | |
206 | #define USB_DEVICE_ID_LD_MOBILECASSY 0x1020 | |
207 | #define USB_DEVICE_ID_LD_JWM 0x1080 | |
208 | #define USB_DEVICE_ID_LD_DMMP 0x1081 | |
209 | #define USB_DEVICE_ID_LD_UMIP 0x1090 | |
210 | #define USB_DEVICE_ID_LD_XRAY1 0x1100 | |
211 | #define USB_DEVICE_ID_LD_XRAY2 0x1101 | |
212 | #define USB_DEVICE_ID_LD_VIDEOCOM 0x1200 | |
213 | #define USB_DEVICE_ID_LD_COM3LAB 0x2000 | |
214 | #define USB_DEVICE_ID_LD_TELEPORT 0x2010 | |
215 | #define USB_DEVICE_ID_LD_NETWORKANALYSER 0x2020 | |
216 | #define USB_DEVICE_ID_LD_POWERCONTROL 0x2030 | |
217 | #define USB_DEVICE_ID_LD_MACHINETEST 0x2040 | |
218 | ||
219 | #define USB_VENDOR_ID_LOGITECH 0x046d | |
220 | #define USB_DEVICE_ID_LOGITECH_RECEIVER 0xc101 | |
9fdcfed8 PD |
221 | #define USB_DEVICE_ID_LOGITECH_HARMONY 0xc110 |
222 | #define USB_DEVICE_ID_LOGITECH_HARMONY_2 0xc111 | |
223 | #define USB_DEVICE_ID_LOGITECH_HARMONY_3 0xc112 | |
224 | #define USB_DEVICE_ID_LOGITECH_HARMONY_4 0xc113 | |
225 | #define USB_DEVICE_ID_LOGITECH_HARMONY_5 0xc114 | |
226 | #define USB_DEVICE_ID_LOGITECH_HARMONY_6 0xc115 | |
227 | #define USB_DEVICE_ID_LOGITECH_HARMONY_7 0xc116 | |
228 | #define USB_DEVICE_ID_LOGITECH_HARMONY_8 0xc117 | |
229 | #define USB_DEVICE_ID_LOGITECH_HARMONY_9 0xc118 | |
230 | #define USB_DEVICE_ID_LOGITECH_HARMONY_10 0xc119 | |
231 | #define USB_DEVICE_ID_LOGITECH_HARMONY_11 0xc11a | |
232 | #define USB_DEVICE_ID_LOGITECH_HARMONY_12 0xc11b | |
233 | #define USB_DEVICE_ID_LOGITECH_HARMONY_13 0xc11c | |
234 | #define USB_DEVICE_ID_LOGITECH_HARMONY_14 0xc11d | |
235 | #define USB_DEVICE_ID_LOGITECH_HARMONY_15 0xc11e | |
236 | #define USB_DEVICE_ID_LOGITECH_HARMONY_16 0xc11f | |
237 | #define USB_DEVICE_ID_LOGITECH_HARMONY_17 0xc120 | |
238 | #define USB_DEVICE_ID_LOGITECH_HARMONY_18 0xc121 | |
239 | #define USB_DEVICE_ID_LOGITECH_HARMONY_19 0xc122 | |
240 | #define USB_DEVICE_ID_LOGITECH_HARMONY_20 0xc123 | |
241 | #define USB_DEVICE_ID_LOGITECH_HARMONY_21 0xc124 | |
242 | #define USB_DEVICE_ID_LOGITECH_HARMONY_22 0xc125 | |
243 | #define USB_DEVICE_ID_LOGITECH_HARMONY_23 0xc126 | |
244 | #define USB_DEVICE_ID_LOGITECH_HARMONY_24 0xc127 | |
245 | #define USB_DEVICE_ID_LOGITECH_HARMONY_25 0xc128 | |
246 | #define USB_DEVICE_ID_LOGITECH_HARMONY_26 0xc129 | |
247 | #define USB_DEVICE_ID_LOGITECH_HARMONY_27 0xc12a | |
248 | #define USB_DEVICE_ID_LOGITECH_HARMONY_28 0xc12b | |
249 | #define USB_DEVICE_ID_LOGITECH_HARMONY_29 0xc12c | |
250 | #define USB_DEVICE_ID_LOGITECH_HARMONY_30 0xc12d | |
251 | #define USB_DEVICE_ID_LOGITECH_HARMONY_31 0xc12e | |
252 | #define USB_DEVICE_ID_LOGITECH_HARMONY_32 0xc12f | |
253 | #define USB_DEVICE_ID_LOGITECH_HARMONY_33 0xc130 | |
254 | #define USB_DEVICE_ID_LOGITECH_HARMONY_34 0xc131 | |
255 | #define USB_DEVICE_ID_LOGITECH_HARMONY_35 0xc132 | |
256 | #define USB_DEVICE_ID_LOGITECH_HARMONY_36 0xc133 | |
257 | #define USB_DEVICE_ID_LOGITECH_HARMONY_37 0xc134 | |
258 | #define USB_DEVICE_ID_LOGITECH_HARMONY_38 0xc135 | |
259 | #define USB_DEVICE_ID_LOGITECH_HARMONY_39 0xc136 | |
260 | #define USB_DEVICE_ID_LOGITECH_HARMONY_40 0xc137 | |
261 | #define USB_DEVICE_ID_LOGITECH_HARMONY_41 0xc138 | |
262 | #define USB_DEVICE_ID_LOGITECH_HARMONY_42 0xc139 | |
263 | #define USB_DEVICE_ID_LOGITECH_HARMONY_43 0xc13a | |
264 | #define USB_DEVICE_ID_LOGITECH_HARMONY_44 0xc13b | |
265 | #define USB_DEVICE_ID_LOGITECH_HARMONY_45 0xc13c | |
266 | #define USB_DEVICE_ID_LOGITECH_HARMONY_46 0xc13d | |
267 | #define USB_DEVICE_ID_LOGITECH_HARMONY_47 0xc13e | |
268 | #define USB_DEVICE_ID_LOGITECH_HARMONY_48 0xc13f | |
269 | #define USB_DEVICE_ID_LOGITECH_HARMONY_49 0xc140 | |
270 | #define USB_DEVICE_ID_LOGITECH_HARMONY_50 0xc141 | |
271 | #define USB_DEVICE_ID_LOGITECH_HARMONY_51 0xc142 | |
272 | #define USB_DEVICE_ID_LOGITECH_HARMONY_52 0xc143 | |
273 | #define USB_DEVICE_ID_LOGITECH_HARMONY_53 0xc144 | |
274 | #define USB_DEVICE_ID_LOGITECH_HARMONY_54 0xc145 | |
275 | #define USB_DEVICE_ID_LOGITECH_HARMONY_55 0xc146 | |
276 | #define USB_DEVICE_ID_LOGITECH_HARMONY_56 0xc147 | |
277 | #define USB_DEVICE_ID_LOGITECH_HARMONY_57 0xc148 | |
278 | #define USB_DEVICE_ID_LOGITECH_HARMONY_58 0xc149 | |
279 | #define USB_DEVICE_ID_LOGITECH_HARMONY_59 0xc14a | |
280 | #define USB_DEVICE_ID_LOGITECH_HARMONY_60 0xc14b | |
281 | #define USB_DEVICE_ID_LOGITECH_HARMONY_61 0xc14c | |
282 | #define USB_DEVICE_ID_LOGITECH_HARMONY_62 0xc14d | |
283 | #define USB_DEVICE_ID_LOGITECH_HARMONY_63 0xc14e | |
284 | #define USB_DEVICE_ID_LOGITECH_HARMONY_64 0xc14f | |
fed76ab3 | 285 | #define USB_DEVICE_ID_LOGITECH_WHEEL 0xc294 |
bc370733 | 286 | #define USB_DEVICE_ID_LOGITECH_ELITE_KBD 0xc30a |
3c5f4b25 | 287 | #define USB_DEVICE_ID_LOGITECH_KBD 0xc311 |
2eb5dc30 PW |
288 | #define USB_DEVICE_ID_S510_RECEIVER 0xc50c |
289 | #define USB_DEVICE_ID_S510_RECEIVER_2 0xc517 | |
5f9c464a | 290 | #define USB_DEVICE_ID_LOGITECH_CORDLESS_DESKTOP_LX500 0xc512 |
2eb5dc30 PW |
291 | #define USB_DEVICE_ID_MX3000_RECEIVER 0xc513 |
292 | #define USB_DEVICE_ID_DINOVO_EDGE 0xc714 | |
293 | ||
294 | #define USB_VENDOR_ID_MCC 0x09db | |
295 | #define USB_DEVICE_ID_MCC_PMD1024LS 0x0076 | |
296 | #define USB_DEVICE_ID_MCC_PMD1208LS 0x007a | |
297 | ||
298 | #define USB_VENDOR_ID_MGE 0x0463 | |
299 | #define USB_DEVICE_ID_MGE_UPS 0xffff | |
300 | #define USB_DEVICE_ID_MGE_UPS1 0x0001 | |
301 | ||
defd2086 JK |
302 | #define USB_VENDOR_ID_MICROSOFT 0x045e |
303 | #define USB_DEVICE_ID_SIDEWINDER_GV 0x003b | |
8dcd5afa | 304 | #define USB_DEVICE_ID_WIRELESS_OPTICAL_DESKTOP_3_0 0x009d |
defd2086 | 305 | |
af9e0eac JK |
306 | #define USB_VENDOR_ID_MONTEREY 0x0566 |
307 | #define USB_DEVICE_ID_GENIUS_KB29E 0x3004 | |
308 | ||
b8e98f1c JK |
309 | #define USB_VENDOR_ID_NCR 0x0404 |
310 | #define USB_DEVICE_ID_NCR_FIRST 0x0300 | |
311 | #define USB_DEVICE_ID_NCR_LAST 0x03ff | |
312 | ||
9fdcfed8 PD |
313 | #define USB_VENDOR_ID_NATIONAL_SEMICONDUCTOR 0x0400 |
314 | #define USB_DEVICE_ID_N_S_HARMONY 0xc359 | |
315 | ||
2eb5dc30 PW |
316 | #define USB_VENDOR_ID_NEC 0x073e |
317 | #define USB_DEVICE_ID_NEC_USB_GAME_PAD 0x0301 | |
318 | ||
319 | #define USB_VENDOR_ID_ONTRAK 0x0a07 | |
320 | #define USB_DEVICE_ID_ONTRAK_ADU100 0x0064 | |
321 | ||
322 | #define USB_VENDOR_ID_PANJIT 0x134c | |
323 | ||
324 | #define USB_VENDOR_ID_PANTHERLORD 0x0810 | |
325 | #define USB_DEVICE_ID_PANTHERLORD_TWIN_USB_JOYSTICK 0x0001 | |
326 | ||
92d9e6e6 JK |
327 | #define USB_VENDOR_ID_PETALYNX 0x18b1 |
328 | #define USB_DEVICE_ID_PETALYNX_MAXTER_REMOTE 0x0037 | |
329 | ||
2eb5dc30 PW |
330 | #define USB_VENDOR_ID_PLAYDOTCOM 0x0b43 |
331 | #define USB_DEVICE_ID_PLAYDOTCOM_EMS_USBII 0x0003 | |
332 | ||
333 | #define USB_VENDOR_ID_SAITEK 0x06a3 | |
334 | #define USB_DEVICE_ID_SAITEK_RUMBLEPAD 0xff17 | |
335 | ||
336 | #define USB_VENDOR_ID_SONY 0x054c | |
337 | #define USB_DEVICE_ID_SONY_PS3_CONTROLLER 0x0268 | |
338 | ||
339 | #define USB_VENDOR_ID_SUN 0x0430 | |
340 | #define USB_DEVICE_ID_RARITAN_KVM_DONGLE 0xcdab | |
341 | ||
342 | #define USB_VENDOR_ID_TOPMAX 0x0663 | |
343 | #define USB_DEVICE_ID_TOPMAX_COBRAPAD 0x0103 | |
344 | ||
345 | #define USB_VENDOR_ID_TURBOX 0x062a | |
346 | #define USB_DEVICE_ID_TURBOX_KEYBOARD 0x0201 | |
347 | ||
348 | #define USB_VENDOR_ID_VERNIER 0x08f7 | |
349 | #define USB_DEVICE_ID_VERNIER_LABPRO 0x0001 | |
350 | #define USB_DEVICE_ID_VERNIER_GOTEMP 0x0002 | |
351 | #define USB_DEVICE_ID_VERNIER_SKIP 0x0003 | |
352 | #define USB_DEVICE_ID_VERNIER_CYCLOPS 0x0004 | |
353 | ||
354 | #define USB_VENDOR_ID_WACOM 0x056a | |
355 | ||
356 | #define USB_VENDOR_ID_WISEGROUP 0x0925 | |
357 | #define USB_DEVICE_ID_1_PHIDGETSERVO_20 0x8101 | |
358 | #define USB_DEVICE_ID_4_PHIDGETSERVO_20 0x8104 | |
359 | #define USB_DEVICE_ID_8_8_4_IF_KIT 0x8201 | |
360 | #define USB_DEVICE_ID_QUAD_USB_JOYPAD 0x8800 | |
361 | #define USB_DEVICE_ID_DUAL_USB_JOYPAD 0x8866 | |
362 | ||
363 | #define USB_VENDOR_ID_WISEGROUP_LTD 0x6677 | |
364 | #define USB_DEVICE_ID_SMARTJOY_DUAL_PLUS 0x8802 | |
365 | ||
366 | #define USB_VENDOR_ID_YEALINK 0x6993 | |
367 | #define USB_DEVICE_ID_YEALINK_P1K_P4K_B2K 0xb001 | |
368 | ||
369 | /* | |
370 | * Alphabetically sorted blacklist by quirk type. | |
371 | */ | |
372 | ||
373 | static const struct hid_blacklist { | |
374 | __u16 idVendor; | |
375 | __u16 idProduct; | |
376 | __u32 quirks; | |
377 | } hid_blacklist[] = { | |
378 | ||
379 | { USB_VENDOR_ID_A4TECH, USB_DEVICE_ID_A4TECH_WCP32PU, HID_QUIRK_2WHEEL_MOUSE_HACK_7 }, | |
c80e5ffa | 380 | { USB_VENDOR_ID_A4TECH, USB_DEVICE_ID_A4TECH_X5_005D, HID_QUIRK_2WHEEL_MOUSE_HACK_B8 }, |
2eb5dc30 PW |
381 | { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_MOUSE, HID_QUIRK_2WHEEL_MOUSE_HACK_5 }, |
382 | ||
383 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_RECEIVER, HID_QUIRK_BAD_RELATIVE_KEYS }, | |
384 | ||
385 | { USB_VENDOR_ID_AASHIMA, USB_DEVICE_ID_AASHIMA_GAMEPAD, HID_QUIRK_BADPAD }, | |
386 | { USB_VENDOR_ID_AASHIMA, USB_DEVICE_ID_AASHIMA_PREDATOR, HID_QUIRK_BADPAD }, | |
387 | { USB_VENDOR_ID_ALPS, USB_DEVICE_ID_IBM_GAMEPAD, HID_QUIRK_BADPAD }, | |
388 | { USB_VENDOR_ID_CHIC, USB_DEVICE_ID_CHIC_GAMEPAD, HID_QUIRK_BADPAD }, | |
1b3ebe93 | 389 | { USB_VENDOR_ID_GAMERON, USB_DEVICE_ID_GAMERON_DUAL_PSX_ADAPTOR, HID_QUIRK_MULTI_INPUT }, |
2eb5dc30 PW |
390 | { USB_VENDOR_ID_HAPP, USB_DEVICE_ID_UGCI_DRIVING, HID_QUIRK_BADPAD | HID_QUIRK_MULTI_INPUT }, |
391 | { USB_VENDOR_ID_HAPP, USB_DEVICE_ID_UGCI_FLYING, HID_QUIRK_BADPAD | HID_QUIRK_MULTI_INPUT }, | |
392 | { USB_VENDOR_ID_HAPP, USB_DEVICE_ID_UGCI_FIGHTING, HID_QUIRK_BADPAD | HID_QUIRK_MULTI_INPUT }, | |
393 | { USB_VENDOR_ID_NEC, USB_DEVICE_ID_NEC_USB_GAME_PAD, HID_QUIRK_BADPAD }, | |
394 | { USB_VENDOR_ID_SAITEK, USB_DEVICE_ID_SAITEK_RUMBLEPAD, HID_QUIRK_BADPAD }, | |
395 | { USB_VENDOR_ID_TOPMAX, USB_DEVICE_ID_TOPMAX_COBRAPAD, HID_QUIRK_BADPAD }, | |
396 | ||
2eb5dc30 PW |
397 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_DINOVO_EDGE, HID_QUIRK_DUPLICATE_USAGES }, |
398 | ||
399 | { USB_VENDOR_ID_BELKIN, USB_DEVICE_ID_FLIP_KVM, HID_QUIRK_HIDDEV }, | |
0ce91cf9 | 400 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_IRCONTROL4, HID_QUIRK_HIDDEV | HID_QUIRK_IGNORE_HIDINPUT }, |
defd2086 | 401 | { USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_SIDEWINDER_GV, HID_QUIRK_HIDINPUT }, |
2eb5dc30 PW |
402 | |
403 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_01, HID_QUIRK_IGNORE }, | |
404 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_10, HID_QUIRK_IGNORE }, | |
405 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_20, HID_QUIRK_IGNORE }, | |
406 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_21, HID_QUIRK_IGNORE }, | |
407 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_22, HID_QUIRK_IGNORE }, | |
408 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_23, HID_QUIRK_IGNORE }, | |
409 | { USB_VENDOR_ID_AIPTEK, USB_DEVICE_ID_AIPTEK_24, HID_QUIRK_IGNORE }, | |
410 | { USB_VENDOR_ID_AIRCABLE, USB_DEVICE_ID_AIRCABLE1, HID_QUIRK_IGNORE }, | |
411 | { USB_VENDOR_ID_ALCOR, USB_DEVICE_ID_ALCOR_USBRS232, HID_QUIRK_IGNORE }, | |
04a9b7ff | 412 | { USB_VENDOR_ID_ASUS, USB_DEVICE_ID_ASUS_LCM, HID_QUIRK_IGNORE}, |
2eb5dc30 PW |
413 | { USB_VENDOR_ID_BERKSHIRE, USB_DEVICE_ID_BERKSHIRE_PCWD, HID_QUIRK_IGNORE }, |
414 | { USB_VENDOR_ID_CIDC, 0x0103, HID_QUIRK_IGNORE }, | |
c4025ade | 415 | { USB_VENDOR_ID_CMEDIA, USB_DEVICE_ID_CM109, HID_QUIRK_IGNORE }, |
2eb5dc30 PW |
416 | { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_HIDCOM, HID_QUIRK_IGNORE }, |
417 | { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_ULTRAMOUSE, HID_QUIRK_IGNORE }, | |
418 | { USB_VENDOR_ID_DELORME, USB_DEVICE_ID_DELORME_EARTHMATE, HID_QUIRK_IGNORE }, | |
419 | { USB_VENDOR_ID_DELORME, USB_DEVICE_ID_DELORME_EM_LT20, HID_QUIRK_IGNORE }, | |
420 | { USB_VENDOR_ID_ESSENTIAL_REALITY, USB_DEVICE_ID_ESSENTIAL_REALITY_P5, HID_QUIRK_IGNORE }, | |
44694359 IF |
421 | { USB_VENDOR_ID_GENERAL_TOUCH, 0x0001, HID_QUIRK_IGNORE }, |
422 | { USB_VENDOR_ID_GENERAL_TOUCH, 0x0002, HID_QUIRK_IGNORE }, | |
423 | { USB_VENDOR_ID_GENERAL_TOUCH, 0x0003, HID_QUIRK_IGNORE }, | |
424 | { USB_VENDOR_ID_GENERAL_TOUCH, 0x0004, HID_QUIRK_IGNORE }, | |
2eb5dc30 PW |
425 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_4_PHIDGETSERVO_30, HID_QUIRK_IGNORE }, |
426 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_1_PHIDGETSERVO_30, HID_QUIRK_IGNORE }, | |
427 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_0_0_4_IF_KIT, HID_QUIRK_IGNORE }, | |
428 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_0_16_16_IF_KIT, HID_QUIRK_IGNORE }, | |
429 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_8_8_8_IF_KIT, HID_QUIRK_IGNORE }, | |
430 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_0_8_7_IF_KIT, HID_QUIRK_IGNORE }, | |
431 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_0_8_8_IF_KIT, HID_QUIRK_IGNORE }, | |
432 | { USB_VENDOR_ID_GLAB, USB_DEVICE_ID_PHIDGET_MOTORCONTROL, HID_QUIRK_IGNORE }, | |
df7bded7 JJ |
433 | { USB_VENDOR_ID_GOTOP, USB_DEVICE_ID_SUPER_Q2, HID_QUIRK_IGNORE }, |
434 | { USB_VENDOR_ID_GOTOP, USB_DEVICE_ID_GOGOPEN, HID_QUIRK_IGNORE }, | |
435 | { USB_VENDOR_ID_GOTOP, USB_DEVICE_ID_PENPOWER, HID_QUIRK_IGNORE }, | |
2eb5dc30 PW |
436 | { USB_VENDOR_ID_GRIFFIN, USB_DEVICE_ID_POWERMATE, HID_QUIRK_IGNORE }, |
437 | { USB_VENDOR_ID_GRIFFIN, USB_DEVICE_ID_SOUNDKNOB, HID_QUIRK_IGNORE }, | |
438 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_90, HID_QUIRK_IGNORE }, | |
439 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_100, HID_QUIRK_IGNORE }, | |
440 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_101, HID_QUIRK_IGNORE }, | |
441 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_103, HID_QUIRK_IGNORE }, | |
442 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_104, HID_QUIRK_IGNORE }, | |
443 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_105, HID_QUIRK_IGNORE }, | |
444 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_106, HID_QUIRK_IGNORE }, | |
445 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_107, HID_QUIRK_IGNORE }, | |
446 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_108, HID_QUIRK_IGNORE }, | |
447 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_200, HID_QUIRK_IGNORE }, | |
448 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_201, HID_QUIRK_IGNORE }, | |
449 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_202, HID_QUIRK_IGNORE }, | |
450 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_203, HID_QUIRK_IGNORE }, | |
451 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_204, HID_QUIRK_IGNORE }, | |
452 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_205, HID_QUIRK_IGNORE }, | |
453 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_206, HID_QUIRK_IGNORE }, | |
454 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_207, HID_QUIRK_IGNORE }, | |
455 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_300, HID_QUIRK_IGNORE }, | |
456 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_301, HID_QUIRK_IGNORE }, | |
457 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_302, HID_QUIRK_IGNORE }, | |
458 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_303, HID_QUIRK_IGNORE }, | |
459 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_304, HID_QUIRK_IGNORE }, | |
460 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_305, HID_QUIRK_IGNORE }, | |
461 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_306, HID_QUIRK_IGNORE }, | |
462 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_307, HID_QUIRK_IGNORE }, | |
463 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_308, HID_QUIRK_IGNORE }, | |
464 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_309, HID_QUIRK_IGNORE }, | |
465 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_400, HID_QUIRK_IGNORE }, | |
466 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_401, HID_QUIRK_IGNORE }, | |
467 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_402, HID_QUIRK_IGNORE }, | |
468 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_403, HID_QUIRK_IGNORE }, | |
469 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_404, HID_QUIRK_IGNORE }, | |
470 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_405, HID_QUIRK_IGNORE }, | |
471 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_500, HID_QUIRK_IGNORE }, | |
472 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_501, HID_QUIRK_IGNORE }, | |
473 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_502, HID_QUIRK_IGNORE }, | |
474 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_503, HID_QUIRK_IGNORE }, | |
475 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_504, HID_QUIRK_IGNORE }, | |
476 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1000, HID_QUIRK_IGNORE }, | |
477 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1001, HID_QUIRK_IGNORE }, | |
478 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1002, HID_QUIRK_IGNORE }, | |
479 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1003, HID_QUIRK_IGNORE }, | |
480 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1004, HID_QUIRK_IGNORE }, | |
481 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1005, HID_QUIRK_IGNORE }, | |
482 | { USB_VENDOR_ID_GTCO, USB_DEVICE_ID_GTCO_1006, HID_QUIRK_IGNORE }, | |
483 | { USB_VENDOR_ID_IMATION, USB_DEVICE_ID_DISC_STAKKA, HID_QUIRK_IGNORE }, | |
484 | { USB_VENDOR_ID_KBGEAR, USB_DEVICE_ID_KBGEAR_JAMSTUDIO, HID_QUIRK_IGNORE }, | |
485 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_CASSY, HID_QUIRK_IGNORE }, | |
486 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_POCKETCASSY, HID_QUIRK_IGNORE }, | |
487 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_MOBILECASSY, HID_QUIRK_IGNORE }, | |
488 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_JWM, HID_QUIRK_IGNORE }, | |
489 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_DMMP, HID_QUIRK_IGNORE }, | |
490 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_UMIP, HID_QUIRK_IGNORE }, | |
491 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_XRAY1, HID_QUIRK_IGNORE }, | |
492 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_XRAY2, HID_QUIRK_IGNORE }, | |
493 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_VIDEOCOM, HID_QUIRK_IGNORE }, | |
494 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_COM3LAB, HID_QUIRK_IGNORE }, | |
495 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_TELEPORT, HID_QUIRK_IGNORE }, | |
496 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_NETWORKANALYSER, HID_QUIRK_IGNORE }, | |
497 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_POWERCONTROL, HID_QUIRK_IGNORE }, | |
498 | { USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_MACHINETEST, HID_QUIRK_IGNORE }, | |
499 | { USB_VENDOR_ID_MCC, USB_DEVICE_ID_MCC_PMD1024LS, HID_QUIRK_IGNORE }, | |
500 | { USB_VENDOR_ID_MCC, USB_DEVICE_ID_MCC_PMD1208LS, HID_QUIRK_IGNORE }, | |
501 | { USB_VENDOR_ID_MGE, USB_DEVICE_ID_MGE_UPS, HID_QUIRK_IGNORE }, | |
502 | { USB_VENDOR_ID_MGE, USB_DEVICE_ID_MGE_UPS1, HID_QUIRK_IGNORE }, | |
503 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100, HID_QUIRK_IGNORE }, | |
504 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 20, HID_QUIRK_IGNORE }, | |
505 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 30, HID_QUIRK_IGNORE }, | |
506 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 100, HID_QUIRK_IGNORE }, | |
507 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 108, HID_QUIRK_IGNORE }, | |
508 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 118, HID_QUIRK_IGNORE }, | |
509 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 200, HID_QUIRK_IGNORE }, | |
510 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 300, HID_QUIRK_IGNORE }, | |
511 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 400, HID_QUIRK_IGNORE }, | |
512 | { USB_VENDOR_ID_ONTRAK, USB_DEVICE_ID_ONTRAK_ADU100 + 500, HID_QUIRK_IGNORE }, | |
513 | { USB_VENDOR_ID_PANJIT, 0x0001, HID_QUIRK_IGNORE }, | |
514 | { USB_VENDOR_ID_PANJIT, 0x0002, HID_QUIRK_IGNORE }, | |
515 | { USB_VENDOR_ID_PANJIT, 0x0003, HID_QUIRK_IGNORE }, | |
516 | { USB_VENDOR_ID_PANJIT, 0x0004, HID_QUIRK_IGNORE }, | |
517 | { USB_VENDOR_ID_VERNIER, USB_DEVICE_ID_VERNIER_LABPRO, HID_QUIRK_IGNORE }, | |
518 | { USB_VENDOR_ID_VERNIER, USB_DEVICE_ID_VERNIER_GOTEMP, HID_QUIRK_IGNORE }, | |
519 | { USB_VENDOR_ID_VERNIER, USB_DEVICE_ID_VERNIER_SKIP, HID_QUIRK_IGNORE }, | |
520 | { USB_VENDOR_ID_VERNIER, USB_DEVICE_ID_VERNIER_CYCLOPS, HID_QUIRK_IGNORE }, | |
521 | { USB_VENDOR_ID_WISEGROUP, USB_DEVICE_ID_4_PHIDGETSERVO_20, HID_QUIRK_IGNORE }, | |
522 | { USB_VENDOR_ID_WISEGROUP, USB_DEVICE_ID_1_PHIDGETSERVO_20, HID_QUIRK_IGNORE }, | |
523 | { USB_VENDOR_ID_WISEGROUP, USB_DEVICE_ID_8_8_4_IF_KIT, HID_QUIRK_IGNORE }, | |
524 | { USB_VENDOR_ID_YEALINK, USB_DEVICE_ID_YEALINK_P1K_P4K_B2K, HID_QUIRK_IGNORE }, | |
525 | ||
526 | { USB_VENDOR_ID_ACECAD, USB_DEVICE_ID_ACECAD_FLAIR, HID_QUIRK_IGNORE }, | |
527 | { USB_VENDOR_ID_ACECAD, USB_DEVICE_ID_ACECAD_302, HID_QUIRK_IGNORE }, | |
528 | ||
bc370733 | 529 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_ELITE_KBD, HID_QUIRK_LOGITECH_IGNORE_DOUBLED_WHEEL | HID_QUIRK_LOGITECH_EXPANDED_KEYMAP }, |
5f9c464a | 530 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_CORDLESS_DESKTOP_LX500, HID_QUIRK_LOGITECH_IGNORE_DOUBLED_WHEEL | HID_QUIRK_LOGITECH_EXPANDED_KEYMAP }, |
2eb5dc30 PW |
531 | |
532 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_MIGHTYMOUSE, HID_QUIRK_MIGHTYMOUSE | HID_QUIRK_INVERT_HWHEEL }, | |
533 | ||
534 | { USB_VENDOR_ID_PANTHERLORD, USB_DEVICE_ID_PANTHERLORD_TWIN_USB_JOYSTICK, HID_QUIRK_MULTI_INPUT | HID_QUIRK_SKIP_OUTPUT_REPORTS }, | |
535 | { USB_VENDOR_ID_PLAYDOTCOM, USB_DEVICE_ID_PLAYDOTCOM_EMS_USBII, HID_QUIRK_MULTI_INPUT }, | |
536 | ||
537 | { USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS3_CONTROLLER, HID_QUIRK_SONY_PS3_CONTROLLER }, | |
538 | ||
539 | { USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_UC100KM, HID_QUIRK_NOGET }, | |
540 | { USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_CS124U, HID_QUIRK_NOGET }, | |
541 | { USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_2PORTKVM, HID_QUIRK_NOGET }, | |
542 | { USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_4PORTKVM, HID_QUIRK_NOGET }, | |
543 | { USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_4PORTKVMC, HID_QUIRK_NOGET }, | |
d500d116 | 544 | { USB_VENDOR_ID_ELO, USB_DEVICE_ID_ELO_TS2700, HID_QUIRK_NOGET }, |
fed76ab3 | 545 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_WHEEL, HID_QUIRK_NOGET }, |
8dcd5afa | 546 | { USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_WIRELESS_OPTICAL_DESKTOP_3_0, HID_QUIRK_NOGET }, |
ea9a4a8b | 547 | { USB_VENDOR_ID_PETALYNX, USB_DEVICE_ID_PETALYNX_MAXTER_REMOTE, HID_QUIRK_NOGET }, |
2eb5dc30 PW |
548 | { USB_VENDOR_ID_SUN, USB_DEVICE_ID_RARITAN_KVM_DONGLE, HID_QUIRK_NOGET }, |
549 | { USB_VENDOR_ID_TURBOX, USB_DEVICE_ID_TURBOX_KEYBOARD, HID_QUIRK_NOGET }, | |
550 | { USB_VENDOR_ID_WISEGROUP, USB_DEVICE_ID_DUAL_USB_JOYPAD, HID_QUIRK_NOGET | HID_QUIRK_MULTI_INPUT }, | |
551 | { USB_VENDOR_ID_WISEGROUP, USB_DEVICE_ID_QUAD_USB_JOYPAD, HID_QUIRK_NOGET | HID_QUIRK_MULTI_INPUT }, | |
552 | ||
553 | { USB_VENDOR_ID_WISEGROUP_LTD, USB_DEVICE_ID_SMARTJOY_DUAL_PLUS, HID_QUIRK_NOGET | HID_QUIRK_MULTI_INPUT }, | |
554 | ||
81e1a875 MD |
555 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_FOUNTAIN_ANSI, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, |
556 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_FOUNTAIN_ISO, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
557 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER_ANSI, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
558 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER_ISO, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE | HID_QUIRK_APPLE_ISO_KEYBOARD}, | |
559 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER_JIS, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
560 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER3_ANSI, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
561 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER3_ISO, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE | HID_QUIRK_APPLE_ISO_KEYBOARD}, | |
562 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER3_JIS, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
563 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER4_ANSI, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
564 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER4_ISO, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE | HID_QUIRK_APPLE_ISO_KEYBOARD}, | |
565 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER4_JIS, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
a45d82d1 MD |
566 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_ANSI, HID_QUIRK_APPLE_HAS_FN }, |
567 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_ISO, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_APPLE_ISO_KEYBOARD }, | |
568 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_JIS, HID_QUIRK_APPLE_HAS_FN }, | |
81e1a875 MD |
569 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_FOUNTAIN_TP_ONLY, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, |
570 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER1_TP_ONLY, HID_QUIRK_APPLE_HAS_FN | HID_QUIRK_IGNORE_MOUSE }, | |
2eb5dc30 PW |
571 | |
572 | { USB_VENDOR_ID_DELL, USB_DEVICE_ID_DELL_W7658, HID_QUIRK_RESET_LEDS }, | |
3c5f4b25 | 573 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_KBD, HID_QUIRK_RESET_LEDS }, |
9fdcfed8 PD |
574 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY, HID_QUIRK_IGNORE }, |
575 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_2, HID_QUIRK_IGNORE }, | |
576 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_3, HID_QUIRK_IGNORE }, | |
577 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_4, HID_QUIRK_IGNORE }, | |
578 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_5, HID_QUIRK_IGNORE }, | |
579 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_6, HID_QUIRK_IGNORE }, | |
580 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_7, HID_QUIRK_IGNORE }, | |
581 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_8, HID_QUIRK_IGNORE }, | |
582 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_9, HID_QUIRK_IGNORE }, | |
583 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_10, HID_QUIRK_IGNORE }, | |
584 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_11, HID_QUIRK_IGNORE }, | |
585 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_12, HID_QUIRK_IGNORE }, | |
586 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_13, HID_QUIRK_IGNORE }, | |
587 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_14, HID_QUIRK_IGNORE }, | |
588 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_15, HID_QUIRK_IGNORE }, | |
589 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_16, HID_QUIRK_IGNORE }, | |
590 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_17, HID_QUIRK_IGNORE }, | |
591 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_18, HID_QUIRK_IGNORE }, | |
592 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_19, HID_QUIRK_IGNORE }, | |
593 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_20, HID_QUIRK_IGNORE }, | |
594 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_21, HID_QUIRK_IGNORE }, | |
595 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_22, HID_QUIRK_IGNORE }, | |
596 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_23, HID_QUIRK_IGNORE }, | |
597 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_24, HID_QUIRK_IGNORE }, | |
598 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_25, HID_QUIRK_IGNORE }, | |
599 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_26, HID_QUIRK_IGNORE }, | |
600 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_27, HID_QUIRK_IGNORE }, | |
601 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_28, HID_QUIRK_IGNORE }, | |
602 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_29, HID_QUIRK_IGNORE }, | |
603 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_30, HID_QUIRK_IGNORE }, | |
604 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_31, HID_QUIRK_IGNORE }, | |
605 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_32, HID_QUIRK_IGNORE }, | |
606 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_33, HID_QUIRK_IGNORE }, | |
607 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_34, HID_QUIRK_IGNORE }, | |
608 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_35, HID_QUIRK_IGNORE }, | |
609 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_36, HID_QUIRK_IGNORE }, | |
610 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_37, HID_QUIRK_IGNORE }, | |
611 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_38, HID_QUIRK_IGNORE }, | |
612 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_39, HID_QUIRK_IGNORE }, | |
613 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_40, HID_QUIRK_IGNORE }, | |
614 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_41, HID_QUIRK_IGNORE }, | |
615 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_42, HID_QUIRK_IGNORE }, | |
616 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_43, HID_QUIRK_IGNORE }, | |
617 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_44, HID_QUIRK_IGNORE }, | |
618 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_45, HID_QUIRK_IGNORE }, | |
619 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_46, HID_QUIRK_IGNORE }, | |
620 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_47, HID_QUIRK_IGNORE }, | |
621 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_48, HID_QUIRK_IGNORE }, | |
622 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_49, HID_QUIRK_IGNORE }, | |
623 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_50, HID_QUIRK_IGNORE }, | |
624 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_51, HID_QUIRK_IGNORE }, | |
625 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_52, HID_QUIRK_IGNORE }, | |
626 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_53, HID_QUIRK_IGNORE }, | |
627 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_54, HID_QUIRK_IGNORE }, | |
628 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_55, HID_QUIRK_IGNORE }, | |
629 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_56, HID_QUIRK_IGNORE }, | |
630 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_57, HID_QUIRK_IGNORE }, | |
631 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_58, HID_QUIRK_IGNORE }, | |
632 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_59, HID_QUIRK_IGNORE }, | |
633 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_60, HID_QUIRK_IGNORE }, | |
634 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_61, HID_QUIRK_IGNORE }, | |
635 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_62, HID_QUIRK_IGNORE }, | |
636 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_63, HID_QUIRK_IGNORE }, | |
637 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_64, HID_QUIRK_IGNORE }, | |
638 | { USB_VENDOR_ID_NATIONAL_SEMICONDUCTOR, USB_DEVICE_ID_N_S_HARMONY, HID_QUIRK_IGNORE }, | |
2eb5dc30 | 639 | |
ea9a4a8b JK |
640 | { 0, 0 } |
641 | }; | |
642 | ||
643 | /* Quirks for devices which require report descriptor fixup go here */ | |
644 | static const struct hid_rdesc_blacklist { | |
645 | __u16 idVendor; | |
646 | __u16 idProduct; | |
647 | __u32 quirks; | |
648 | } hid_rdesc_blacklist[] = { | |
649 | ||
650 | { USB_VENDOR_ID_CHERRY, USB_DEVICE_ID_CHERRY_CYMOTION, HID_QUIRK_RDESC_CYMOTION }, | |
651 | ||
652 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_MX3000_RECEIVER, HID_QUIRK_RDESC_LOGITECH }, | |
653 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_S510_RECEIVER, HID_QUIRK_RDESC_LOGITECH }, | |
654 | { USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_S510_RECEIVER_2, HID_QUIRK_RDESC_LOGITECH }, | |
655 | ||
af9e0eac JK |
656 | { USB_VENDOR_ID_MONTEREY, USB_DEVICE_ID_GENIUS_KB29E, HID_QUIRK_RDESC_BUTTON_CONSUMER }, |
657 | ||
08f06177 TA |
658 | { USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER4_JIS, HID_QUIRK_RDESC_MACBOOK_JIS }, |
659 | ||
ea9a4a8b JK |
660 | { USB_VENDOR_ID_PETALYNX, USB_DEVICE_ID_PETALYNX_MAXTER_REMOTE, HID_QUIRK_RDESC_PETALYNX }, |
661 | ||
662 | { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_1, HID_QUIRK_RDESC_SWAPPED_MIN_MAX }, | |
663 | { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_2, HID_QUIRK_RDESC_SWAPPED_MIN_MAX }, | |
66da8769 | 664 | |
2eb5dc30 PW |
665 | { 0, 0 } |
666 | }; | |
8cef9082 PW |
667 | |
668 | /* Dynamic HID quirks list - specified at runtime */ | |
669 | struct quirks_list_struct { | |
670 | struct hid_blacklist hid_bl_item; | |
671 | struct list_head node; | |
672 | }; | |
673 | ||
674 | static LIST_HEAD(dquirks_list); | |
675 | static DECLARE_RWSEM(dquirks_rwsem); | |
676 | ||
677 | /* Runtime ("dynamic") quirks manipulation functions */ | |
678 | ||
8222fbe6 | 679 | /** |
8cef9082 PW |
680 | * usbhid_exists_dquirk: find any dynamic quirks for a USB HID device |
681 | * @idVendor: the 16-bit USB vendor ID, in native byteorder | |
682 | * @idProduct: the 16-bit USB product ID, in native byteorder | |
683 | * | |
684 | * Description: | |
685 | * Scans dquirks_list for a matching dynamic quirk and returns | |
686 | * the pointer to the relevant struct hid_blacklist if found. | |
687 | * Must be called with a read lock held on dquirks_rwsem. | |
688 | * | |
689 | * Returns: NULL if no quirk found, struct hid_blacklist * if found. | |
690 | */ | |
691 | static struct hid_blacklist *usbhid_exists_dquirk(const u16 idVendor, | |
692 | const u16 idProduct) | |
693 | { | |
694 | struct quirks_list_struct *q; | |
695 | struct hid_blacklist *bl_entry = NULL; | |
696 | ||
8cef9082 PW |
697 | list_for_each_entry(q, &dquirks_list, node) { |
698 | if (q->hid_bl_item.idVendor == idVendor && | |
699 | q->hid_bl_item.idProduct == idProduct) { | |
700 | bl_entry = &q->hid_bl_item; | |
701 | break; | |
702 | } | |
703 | } | |
704 | ||
705 | if (bl_entry != NULL) | |
58037eb9 | 706 | dbg_hid("Found dynamic quirk 0x%x for USB HID vendor 0x%hx prod 0x%hx\n", |
8cef9082 PW |
707 | bl_entry->quirks, bl_entry->idVendor, |
708 | bl_entry->idProduct); | |
709 | ||
710 | return bl_entry; | |
711 | } | |
712 | ||
713 | ||
714 | /** | |
715 | * usbhid_modify_dquirk: add/replace a HID quirk | |
716 | * @idVendor: the 16-bit USB vendor ID, in native byteorder | |
717 | * @idProduct: the 16-bit USB product ID, in native byteorder | |
718 | * @quirks: the u32 quirks value to add/replace | |
719 | * | |
720 | * Description: | |
721 | * If an dynamic quirk exists in memory for this (idVendor, | |
722 | * idProduct) pair, replace its quirks value with what was | |
723 | * provided. Otherwise, add the quirk to the dynamic quirks list. | |
724 | * | |
725 | * Returns: 0 OK, -error on failure. | |
726 | */ | |
727 | int usbhid_modify_dquirk(const u16 idVendor, const u16 idProduct, | |
728 | const u32 quirks) | |
729 | { | |
730 | struct quirks_list_struct *q_new, *q; | |
731 | int list_edited = 0; | |
732 | ||
733 | if (!idVendor) { | |
58037eb9 | 734 | dbg_hid("Cannot add a quirk with idVendor = 0\n"); |
8cef9082 PW |
735 | return -EINVAL; |
736 | } | |
737 | ||
738 | q_new = kmalloc(sizeof(struct quirks_list_struct), GFP_KERNEL); | |
739 | if (!q_new) { | |
58037eb9 | 740 | dbg_hid("Could not allocate quirks_list_struct\n"); |
8cef9082 PW |
741 | return -ENOMEM; |
742 | } | |
743 | ||
744 | q_new->hid_bl_item.idVendor = idVendor; | |
745 | q_new->hid_bl_item.idProduct = idProduct; | |
746 | q_new->hid_bl_item.quirks = quirks; | |
747 | ||
748 | down_write(&dquirks_rwsem); | |
749 | ||
750 | list_for_each_entry(q, &dquirks_list, node) { | |
751 | ||
752 | if (q->hid_bl_item.idVendor == idVendor && | |
753 | q->hid_bl_item.idProduct == idProduct) { | |
754 | ||
755 | list_replace(&q->node, &q_new->node); | |
756 | kfree(q); | |
757 | list_edited = 1; | |
758 | break; | |
759 | ||
760 | } | |
761 | ||
762 | } | |
763 | ||
764 | if (!list_edited) | |
765 | list_add_tail(&q_new->node, &dquirks_list); | |
766 | ||
767 | up_write(&dquirks_rwsem); | |
768 | ||
769 | return 0; | |
770 | } | |
771 | ||
8cef9082 PW |
772 | /** |
773 | * usbhid_remove_all_dquirks: remove all runtime HID quirks from memory | |
774 | * | |
775 | * Description: | |
776 | * Free all memory associated with dynamic quirks - called before | |
777 | * module unload. | |
778 | * | |
779 | */ | |
780 | static void usbhid_remove_all_dquirks(void) | |
781 | { | |
782 | struct quirks_list_struct *q, *temp; | |
783 | ||
784 | down_write(&dquirks_rwsem); | |
785 | list_for_each_entry_safe(q, temp, &dquirks_list, node) { | |
786 | list_del(&q->node); | |
787 | kfree(q); | |
788 | } | |
789 | up_write(&dquirks_rwsem); | |
790 | ||
791 | } | |
792 | ||
876b9276 PW |
793 | /** |
794 | * usbhid_quirks_init: apply USB HID quirks specified at module load time | |
795 | */ | |
796 | int usbhid_quirks_init(char **quirks_param) | |
797 | { | |
798 | u16 idVendor, idProduct; | |
799 | u32 quirks; | |
800 | int n = 0, m; | |
801 | ||
802 | for (; quirks_param[n] && n < MAX_USBHID_BOOT_QUIRKS; n++) { | |
803 | ||
804 | m = sscanf(quirks_param[n], "0x%hx:0x%hx:0x%x", | |
805 | &idVendor, &idProduct, &quirks); | |
806 | ||
807 | if (m != 3 || | |
808 | usbhid_modify_dquirk(idVendor, idProduct, quirks) != 0) { | |
809 | printk(KERN_WARNING | |
810 | "Could not parse HID quirk module param %s\n", | |
811 | quirks_param[n]); | |
812 | } | |
813 | } | |
814 | ||
815 | return 0; | |
816 | } | |
817 | ||
818 | /** | |
819 | * usbhid_quirks_exit: release memory associated with dynamic_quirks | |
820 | * | |
821 | * Description: | |
822 | * Release all memory associated with dynamic quirks. Called upon | |
823 | * module unload. | |
824 | * | |
825 | * Returns: nothing | |
826 | */ | |
827 | void usbhid_quirks_exit(void) | |
828 | { | |
829 | usbhid_remove_all_dquirks(); | |
830 | } | |
8cef9082 PW |
831 | |
832 | /** | |
833 | * usbhid_exists_squirk: return any static quirks for a USB HID device | |
834 | * @idVendor: the 16-bit USB vendor ID, in native byteorder | |
835 | * @idProduct: the 16-bit USB product ID, in native byteorder | |
836 | * | |
837 | * Description: | |
838 | * Given a USB vendor ID and product ID, return a pointer to | |
839 | * the hid_blacklist entry associated with that device. | |
840 | * | |
841 | * Returns: pointer if quirk found, or NULL if no quirks found. | |
842 | */ | |
8222fbe6 | 843 | static const struct hid_blacklist *usbhid_exists_squirk(const u16 idVendor, |
8cef9082 | 844 | const u16 idProduct) |
8222fbe6 | 845 | { |
8cef9082 PW |
846 | const struct hid_blacklist *bl_entry = NULL; |
847 | int n = 0; | |
8222fbe6 PW |
848 | |
849 | for (; hid_blacklist[n].idVendor; n++) | |
850 | if (hid_blacklist[n].idVendor == idVendor && | |
851 | hid_blacklist[n].idProduct == idProduct) | |
852 | bl_entry = &hid_blacklist[n]; | |
853 | ||
854 | if (bl_entry != NULL) | |
58037eb9 | 855 | dbg_hid("Found squirk 0x%x for USB HID vendor 0x%hx prod 0x%hx\n", |
8222fbe6 PW |
856 | bl_entry->quirks, bl_entry->idVendor, |
857 | bl_entry->idProduct); | |
858 | return bl_entry; | |
859 | } | |
2eb5dc30 PW |
860 | |
861 | /** | |
862 | * usbhid_lookup_quirk: return any quirks associated with a USB HID device | |
863 | * @idVendor: the 16-bit USB vendor ID, in native byteorder | |
864 | * @idProduct: the 16-bit USB product ID, in native byteorder | |
865 | * | |
866 | * Description: | |
867 | * Given a USB vendor ID and product ID, return any quirks associated | |
868 | * with that device. | |
869 | * | |
870 | * Returns: a u32 quirks value. | |
871 | */ | |
872 | u32 usbhid_lookup_quirk(const u16 idVendor, const u16 idProduct) | |
873 | { | |
874 | u32 quirks = 0; | |
8222fbe6 | 875 | const struct hid_blacklist *bl_entry = NULL; |
2eb5dc30 PW |
876 | |
877 | /* Ignore all Wacom devices */ | |
878 | if (idVendor == USB_VENDOR_ID_WACOM) | |
879 | return HID_QUIRK_IGNORE; | |
880 | ||
881 | /* ignore all Code Mercenaries IOWarrior devices */ | |
882 | if (idVendor == USB_VENDOR_ID_CODEMERCS) | |
883 | if (idProduct >= USB_DEVICE_ID_CODEMERCS_IOW_FIRST && | |
884 | idProduct <= USB_DEVICE_ID_CODEMERCS_IOW_LAST) | |
885 | return HID_QUIRK_IGNORE; | |
886 | ||
b8e98f1c JK |
887 | /* NCR devices must not be queried for reports */ |
888 | if (idVendor == USB_VENDOR_ID_NCR && | |
889 | idProduct >= USB_DEVICE_ID_NCR_FIRST && | |
890 | idProduct <= USB_DEVICE_ID_NCR_LAST) | |
891 | return HID_QUIRK_NOGET; | |
892 | ||
8cef9082 PW |
893 | down_read(&dquirks_rwsem); |
894 | bl_entry = usbhid_exists_dquirk(idVendor, idProduct); | |
895 | if (!bl_entry) | |
896 | bl_entry = usbhid_exists_squirk(idVendor, idProduct); | |
8222fbe6 PW |
897 | if (bl_entry) |
898 | quirks = bl_entry->quirks; | |
8cef9082 PW |
899 | up_read(&dquirks_rwsem); |
900 | ||
2eb5dc30 PW |
901 | return quirks; |
902 | } | |
8222fbe6 | 903 | |
ea9a4a8b JK |
904 | /* |
905 | * Cherry Cymotion keyboard have an invalid HID report descriptor, | |
906 | * that needs fixing before we can parse it. | |
907 | */ | |
908 | static void usbhid_fixup_cymotion_descriptor(char *rdesc, int rsize) | |
909 | { | |
910 | if (rsize >= 17 && rdesc[11] == 0x3c && rdesc[12] == 0x02) { | |
911 | printk(KERN_INFO "Fixing up Cherry Cymotion report descriptor\n"); | |
912 | rdesc[11] = rdesc[16] = 0xff; | |
913 | rdesc[12] = rdesc[17] = 0x03; | |
914 | } | |
915 | } | |
916 | ||
917 | ||
918 | /* | |
919 | * Certain Logitech keyboards send in report #3 keys which are far | |
920 | * above the logical maximum described in descriptor. This extends | |
921 | * the original value of 0x28c of logical maximum to 0x104d | |
922 | */ | |
923 | static void usbhid_fixup_logitech_descriptor(unsigned char *rdesc, int rsize) | |
924 | { | |
925 | if (rsize >= 90 && rdesc[83] == 0x26 | |
926 | && rdesc[84] == 0x8c | |
927 | && rdesc[85] == 0x02) { | |
928 | printk(KERN_INFO "Fixing up Logitech keyboard report descriptor\n"); | |
929 | rdesc[84] = rdesc[89] = 0x4d; | |
930 | rdesc[85] = rdesc[90] = 0x10; | |
931 | } | |
932 | } | |
933 | ||
934 | /* Petalynx Maxter Remote has maximum for consumer page set too low */ | |
935 | static void usbhid_fixup_petalynx_descriptor(unsigned char *rdesc, int rsize) | |
936 | { | |
937 | if (rsize >= 60 && rdesc[39] == 0x2a | |
938 | && rdesc[40] == 0xf5 | |
939 | && rdesc[41] == 0x00 | |
940 | && rdesc[59] == 0x26 | |
941 | && rdesc[60] == 0xf9 | |
942 | && rdesc[61] == 0x00) { | |
943 | printk(KERN_INFO "Fixing up Petalynx Maxter Remote report descriptor\n"); | |
944 | rdesc[60] = 0xfa; | |
945 | rdesc[40] = 0xfa; | |
946 | } | |
947 | } | |
948 | ||
949 | /* | |
950 | * Some USB barcode readers from cypress have usage min and usage max in | |
951 | * the wrong order | |
952 | */ | |
953 | static void usbhid_fixup_cypress_descriptor(unsigned char *rdesc, int rsize) | |
954 | { | |
955 | short fixed = 0; | |
956 | int i; | |
957 | ||
958 | for (i = 0; i < rsize - 4; i++) { | |
959 | if (rdesc[i] == 0x29 && rdesc [i+2] == 0x19) { | |
960 | unsigned char tmp; | |
961 | ||
962 | rdesc[i] = 0x19; rdesc[i+2] = 0x29; | |
963 | tmp = rdesc[i+3]; | |
964 | rdesc[i+3] = rdesc[i+1]; | |
965 | rdesc[i+1] = tmp; | |
966 | } | |
967 | } | |
968 | ||
969 | if (fixed) | |
970 | printk(KERN_INFO "Fixing up Cypress report descriptor\n"); | |
971 | } | |
972 | ||
08f06177 TA |
973 | /* |
974 | * MacBook JIS keyboard has wrong logical maximum | |
975 | */ | |
976 | static void usbhid_fixup_macbook_descriptor(unsigned char *rdesc, int rsize) | |
977 | { | |
978 | if (rsize >= 60 && rdesc[53] == 0x65 | |
979 | && rdesc[59] == 0x65) { | |
980 | printk(KERN_INFO "Fixing up MacBook JIS keyboard report descriptor\n"); | |
981 | rdesc[53] = rdesc[59] = 0xe7; | |
982 | } | |
983 | } | |
984 | ||
af9e0eac JK |
985 | static void usbhid_fixup_button_consumer_descriptor(unsigned char *rdesc, int rsize) |
986 | { | |
987 | if (rsize >= 30 && rdesc[29] == 0x05 | |
988 | && rdesc[30] == 0x09) { | |
989 | printk(KERN_INFO "Fixing up button/consumer in HID report descriptor\n"); | |
990 | rdesc[30] = 0x0c; | |
991 | } | |
992 | } | |
ea9a4a8b JK |
993 | |
994 | static void __usbhid_fixup_report_descriptor(__u32 quirks, char *rdesc, unsigned rsize) | |
995 | { | |
996 | if ((quirks & HID_QUIRK_RDESC_CYMOTION)) | |
997 | usbhid_fixup_cymotion_descriptor(rdesc, rsize); | |
998 | ||
999 | if (quirks & HID_QUIRK_RDESC_LOGITECH) | |
1000 | usbhid_fixup_logitech_descriptor(rdesc, rsize); | |
1001 | ||
1002 | if (quirks & HID_QUIRK_RDESC_SWAPPED_MIN_MAX) | |
1003 | usbhid_fixup_cypress_descriptor(rdesc, rsize); | |
1004 | ||
1005 | if (quirks & HID_QUIRK_RDESC_PETALYNX) | |
1006 | usbhid_fixup_petalynx_descriptor(rdesc, rsize); | |
08f06177 TA |
1007 | |
1008 | if (quirks & HID_QUIRK_RDESC_MACBOOK_JIS) | |
1009 | usbhid_fixup_macbook_descriptor(rdesc, rsize); | |
af9e0eac JK |
1010 | |
1011 | if (quirks & HID_QUIRK_RDESC_BUTTON_CONSUMER) | |
1012 | usbhid_fixup_button_consumer_descriptor(rdesc, rsize); | |
ea9a4a8b JK |
1013 | } |
1014 | ||
1015 | /** | |
1016 | * usbhid_fixup_report_descriptor: check if report descriptor needs fixup | |
1017 | * | |
1018 | * Description: | |
1019 | * Walks the hid_rdesc_blacklist[] array and checks whether the device | |
1020 | * is known to have broken report descriptor that needs to be fixed up | |
1021 | * prior to entering the HID parser | |
1022 | * | |
1023 | * Returns: nothing | |
1024 | */ | |
1025 | void usbhid_fixup_report_descriptor(const u16 idVendor, const u16 idProduct, | |
1026 | char *rdesc, unsigned rsize, char **quirks_param) | |
1027 | { | |
1028 | int n, m; | |
1029 | u16 paramVendor, paramProduct; | |
1030 | u32 quirks; | |
1031 | ||
1032 | /* static rdesc quirk entries */ | |
1033 | for (n = 0; hid_rdesc_blacklist[n].idVendor; n++) | |
1034 | if (hid_rdesc_blacklist[n].idVendor == idVendor && | |
1035 | hid_rdesc_blacklist[n].idProduct == idProduct) | |
1036 | __usbhid_fixup_report_descriptor(hid_rdesc_blacklist[n].quirks, | |
1037 | rdesc, rsize); | |
1038 | ||
1039 | /* runtime rdesc quirk entries handling */ | |
1040 | for (n = 0; quirks_param[n] && n < MAX_USBHID_BOOT_QUIRKS; n++) { | |
1041 | m = sscanf(quirks_param[n], "0x%hx:0x%hx:0x%x", | |
1042 | ¶mVendor, ¶mProduct, &quirks); | |
1043 | ||
1044 | if (m != 3) | |
1045 | printk(KERN_WARNING | |
1046 | "Could not parse HID quirk module param %s\n", | |
1047 | quirks_param[n]); | |
1048 | else if (paramVendor == idVendor && paramProduct == idProduct) | |
1049 | __usbhid_fixup_report_descriptor(quirks, rdesc, rsize); | |
1050 | } | |
1051 | ||
1052 | } |