]>
Commit | Line | Data |
---|---|---|
1 | /* | |
2 | USB Driver for GSM modems | |
3 | ||
4 | Copyright (C) 2005 Matthias Urlichs <smurf@smurf.noris.de> | |
5 | ||
6 | This driver is free software; you can redistribute it and/or modify | |
7 | it under the terms of Version 2 of the GNU General Public License as | |
8 | published by the Free Software Foundation. | |
9 | ||
10 | Portions copied from the Keyspan driver by Hugh Blemings <hugh@blemings.org> | |
11 | ||
12 | History: see the git log. | |
13 | ||
14 | Work sponsored by: Sigos GmbH, Germany <info@sigos.de> | |
15 | ||
16 | This driver exists because the "normal" serial driver doesn't work too well | |
17 | with GSM modems. Issues: | |
18 | - data loss -- one single Receive URB is not nearly enough | |
19 | - nonstandard flow (Option devices) control | |
20 | - controlling the baud rate doesn't make sense | |
21 | ||
22 | This driver is named "option" because the most common device it's | |
23 | used for is a PC-Card (with an internal OHCI-USB interface, behind | |
24 | which the GSM interface sits), made by Option Inc. | |
25 | ||
26 | Some of the "one port" devices actually exhibit multiple USB instances | |
27 | on the USB bus. This is not a bug, these ports are used for different | |
28 | device features. | |
29 | */ | |
30 | ||
31 | #define DRIVER_AUTHOR "Matthias Urlichs <smurf@smurf.noris.de>" | |
32 | #define DRIVER_DESC "USB Driver for GSM modems" | |
33 | ||
34 | #include <linux/kernel.h> | |
35 | #include <linux/jiffies.h> | |
36 | #include <linux/errno.h> | |
37 | #include <linux/tty.h> | |
38 | #include <linux/tty_flip.h> | |
39 | #include <linux/slab.h> | |
40 | #include <linux/module.h> | |
41 | #include <linux/bitops.h> | |
42 | #include <linux/usb.h> | |
43 | #include <linux/usb/serial.h> | |
44 | #include "usb-wwan.h" | |
45 | ||
46 | /* Function prototypes */ | |
47 | static int option_probe(struct usb_serial *serial, | |
48 | const struct usb_device_id *id); | |
49 | static int option_attach(struct usb_serial *serial); | |
50 | static void option_release(struct usb_serial *serial); | |
51 | static int option_send_setup(struct usb_serial_port *port); | |
52 | static void option_instat_callback(struct urb *urb); | |
53 | ||
54 | /* Vendor and product IDs */ | |
55 | #define OPTION_VENDOR_ID 0x0AF0 | |
56 | #define OPTION_PRODUCT_COLT 0x5000 | |
57 | #define OPTION_PRODUCT_RICOLA 0x6000 | |
58 | #define OPTION_PRODUCT_RICOLA_LIGHT 0x6100 | |
59 | #define OPTION_PRODUCT_RICOLA_QUAD 0x6200 | |
60 | #define OPTION_PRODUCT_RICOLA_QUAD_LIGHT 0x6300 | |
61 | #define OPTION_PRODUCT_RICOLA_NDIS 0x6050 | |
62 | #define OPTION_PRODUCT_RICOLA_NDIS_LIGHT 0x6150 | |
63 | #define OPTION_PRODUCT_RICOLA_NDIS_QUAD 0x6250 | |
64 | #define OPTION_PRODUCT_RICOLA_NDIS_QUAD_LIGHT 0x6350 | |
65 | #define OPTION_PRODUCT_COBRA 0x6500 | |
66 | #define OPTION_PRODUCT_COBRA_BUS 0x6501 | |
67 | #define OPTION_PRODUCT_VIPER 0x6600 | |
68 | #define OPTION_PRODUCT_VIPER_BUS 0x6601 | |
69 | #define OPTION_PRODUCT_GT_MAX_READY 0x6701 | |
70 | #define OPTION_PRODUCT_FUJI_MODEM_LIGHT 0x6721 | |
71 | #define OPTION_PRODUCT_FUJI_MODEM_GT 0x6741 | |
72 | #define OPTION_PRODUCT_FUJI_MODEM_EX 0x6761 | |
73 | #define OPTION_PRODUCT_KOI_MODEM 0x6800 | |
74 | #define OPTION_PRODUCT_SCORPION_MODEM 0x6901 | |
75 | #define OPTION_PRODUCT_ETNA_MODEM 0x7001 | |
76 | #define OPTION_PRODUCT_ETNA_MODEM_LITE 0x7021 | |
77 | #define OPTION_PRODUCT_ETNA_MODEM_GT 0x7041 | |
78 | #define OPTION_PRODUCT_ETNA_MODEM_EX 0x7061 | |
79 | #define OPTION_PRODUCT_ETNA_KOI_MODEM 0x7100 | |
80 | #define OPTION_PRODUCT_GTM380_MODEM 0x7201 | |
81 | ||
82 | #define HUAWEI_VENDOR_ID 0x12D1 | |
83 | #define HUAWEI_PRODUCT_K4505 0x1464 | |
84 | #define HUAWEI_PRODUCT_K3765 0x1465 | |
85 | #define HUAWEI_PRODUCT_K4605 0x14C6 | |
86 | ||
87 | #define QUANTA_VENDOR_ID 0x0408 | |
88 | #define QUANTA_PRODUCT_Q101 0xEA02 | |
89 | #define QUANTA_PRODUCT_Q111 0xEA03 | |
90 | #define QUANTA_PRODUCT_GLX 0xEA04 | |
91 | #define QUANTA_PRODUCT_GKE 0xEA05 | |
92 | #define QUANTA_PRODUCT_GLE 0xEA06 | |
93 | ||
94 | #define NOVATELWIRELESS_VENDOR_ID 0x1410 | |
95 | ||
96 | /* YISO PRODUCTS */ | |
97 | ||
98 | #define YISO_VENDOR_ID 0x0EAB | |
99 | #define YISO_PRODUCT_U893 0xC893 | |
100 | ||
101 | /* | |
102 | * NOVATEL WIRELESS PRODUCTS | |
103 | * | |
104 | * Note from Novatel Wireless: | |
105 | * If your Novatel modem does not work on linux, don't | |
106 | * change the option module, but check our website. If | |
107 | * that does not help, contact ddeschepper@nvtl.com | |
108 | */ | |
109 | /* MERLIN EVDO PRODUCTS */ | |
110 | #define NOVATELWIRELESS_PRODUCT_V640 0x1100 | |
111 | #define NOVATELWIRELESS_PRODUCT_V620 0x1110 | |
112 | #define NOVATELWIRELESS_PRODUCT_V740 0x1120 | |
113 | #define NOVATELWIRELESS_PRODUCT_V720 0x1130 | |
114 | ||
115 | /* MERLIN HSDPA/HSPA PRODUCTS */ | |
116 | #define NOVATELWIRELESS_PRODUCT_U730 0x1400 | |
117 | #define NOVATELWIRELESS_PRODUCT_U740 0x1410 | |
118 | #define NOVATELWIRELESS_PRODUCT_U870 0x1420 | |
119 | #define NOVATELWIRELESS_PRODUCT_XU870 0x1430 | |
120 | #define NOVATELWIRELESS_PRODUCT_X950D 0x1450 | |
121 | ||
122 | /* EXPEDITE PRODUCTS */ | |
123 | #define NOVATELWIRELESS_PRODUCT_EV620 0x2100 | |
124 | #define NOVATELWIRELESS_PRODUCT_ES720 0x2110 | |
125 | #define NOVATELWIRELESS_PRODUCT_E725 0x2120 | |
126 | #define NOVATELWIRELESS_PRODUCT_ES620 0x2130 | |
127 | #define NOVATELWIRELESS_PRODUCT_EU730 0x2400 | |
128 | #define NOVATELWIRELESS_PRODUCT_EU740 0x2410 | |
129 | #define NOVATELWIRELESS_PRODUCT_EU870D 0x2420 | |
130 | /* OVATION PRODUCTS */ | |
131 | #define NOVATELWIRELESS_PRODUCT_MC727 0x4100 | |
132 | #define NOVATELWIRELESS_PRODUCT_MC950D 0x4400 | |
133 | /* | |
134 | * Note from Novatel Wireless: | |
135 | * All PID in the 5xxx range are currently reserved for | |
136 | * auto-install CDROMs, and should not be added to this | |
137 | * module. | |
138 | * | |
139 | * #define NOVATELWIRELESS_PRODUCT_U727 0x5010 | |
140 | * #define NOVATELWIRELESS_PRODUCT_MC727_NEW 0x5100 | |
141 | */ | |
142 | #define NOVATELWIRELESS_PRODUCT_OVMC760 0x6002 | |
143 | #define NOVATELWIRELESS_PRODUCT_MC780 0x6010 | |
144 | #define NOVATELWIRELESS_PRODUCT_EVDO_FULLSPEED 0x6000 | |
145 | #define NOVATELWIRELESS_PRODUCT_EVDO_HIGHSPEED 0x6001 | |
146 | #define NOVATELWIRELESS_PRODUCT_HSPA_FULLSPEED 0x7000 | |
147 | #define NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED 0x7001 | |
148 | #define NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED3 0x7003 | |
149 | #define NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED4 0x7004 | |
150 | #define NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED5 0x7005 | |
151 | #define NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED6 0x7006 | |
152 | #define NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED7 0x7007 | |
153 | #define NOVATELWIRELESS_PRODUCT_MC996D 0x7030 | |
154 | #define NOVATELWIRELESS_PRODUCT_MF3470 0x7041 | |
155 | #define NOVATELWIRELESS_PRODUCT_MC547 0x7042 | |
156 | #define NOVATELWIRELESS_PRODUCT_EVDO_EMBEDDED_FULLSPEED 0x8000 | |
157 | #define NOVATELWIRELESS_PRODUCT_EVDO_EMBEDDED_HIGHSPEED 0x8001 | |
158 | #define NOVATELWIRELESS_PRODUCT_HSPA_EMBEDDED_FULLSPEED 0x9000 | |
159 | #define NOVATELWIRELESS_PRODUCT_HSPA_EMBEDDED_HIGHSPEED 0x9001 | |
160 | #define NOVATELWIRELESS_PRODUCT_G1 0xA001 | |
161 | #define NOVATELWIRELESS_PRODUCT_G1_M 0xA002 | |
162 | #define NOVATELWIRELESS_PRODUCT_G2 0xA010 | |
163 | #define NOVATELWIRELESS_PRODUCT_MC551 0xB001 | |
164 | ||
165 | /* AMOI PRODUCTS */ | |
166 | #define AMOI_VENDOR_ID 0x1614 | |
167 | #define AMOI_PRODUCT_H01 0x0800 | |
168 | #define AMOI_PRODUCT_H01A 0x7002 | |
169 | #define AMOI_PRODUCT_H02 0x0802 | |
170 | #define AMOI_PRODUCT_SKYPEPHONE_S2 0x0407 | |
171 | ||
172 | #define DELL_VENDOR_ID 0x413C | |
173 | ||
174 | /* Dell modems */ | |
175 | #define DELL_PRODUCT_5700_MINICARD 0x8114 | |
176 | #define DELL_PRODUCT_5500_MINICARD 0x8115 | |
177 | #define DELL_PRODUCT_5505_MINICARD 0x8116 | |
178 | #define DELL_PRODUCT_5700_EXPRESSCARD 0x8117 | |
179 | #define DELL_PRODUCT_5510_EXPRESSCARD 0x8118 | |
180 | ||
181 | #define DELL_PRODUCT_5700_MINICARD_SPRINT 0x8128 | |
182 | #define DELL_PRODUCT_5700_MINICARD_TELUS 0x8129 | |
183 | ||
184 | #define DELL_PRODUCT_5720_MINICARD_VZW 0x8133 | |
185 | #define DELL_PRODUCT_5720_MINICARD_SPRINT 0x8134 | |
186 | #define DELL_PRODUCT_5720_MINICARD_TELUS 0x8135 | |
187 | #define DELL_PRODUCT_5520_MINICARD_CINGULAR 0x8136 | |
188 | #define DELL_PRODUCT_5520_MINICARD_GENERIC_L 0x8137 | |
189 | #define DELL_PRODUCT_5520_MINICARD_GENERIC_I 0x8138 | |
190 | ||
191 | #define DELL_PRODUCT_5730_MINICARD_SPRINT 0x8180 | |
192 | #define DELL_PRODUCT_5730_MINICARD_TELUS 0x8181 | |
193 | #define DELL_PRODUCT_5730_MINICARD_VZW 0x8182 | |
194 | ||
195 | #define KYOCERA_VENDOR_ID 0x0c88 | |
196 | #define KYOCERA_PRODUCT_KPC650 0x17da | |
197 | #define KYOCERA_PRODUCT_KPC680 0x180a | |
198 | ||
199 | #define ANYDATA_VENDOR_ID 0x16d5 | |
200 | #define ANYDATA_PRODUCT_ADU_620UW 0x6202 | |
201 | #define ANYDATA_PRODUCT_ADU_E100A 0x6501 | |
202 | #define ANYDATA_PRODUCT_ADU_500A 0x6502 | |
203 | ||
204 | #define AXESSTEL_VENDOR_ID 0x1726 | |
205 | #define AXESSTEL_PRODUCT_MV110H 0x1000 | |
206 | ||
207 | #define BANDRICH_VENDOR_ID 0x1A8D | |
208 | #define BANDRICH_PRODUCT_C100_1 0x1002 | |
209 | #define BANDRICH_PRODUCT_C100_2 0x1003 | |
210 | #define BANDRICH_PRODUCT_1004 0x1004 | |
211 | #define BANDRICH_PRODUCT_1005 0x1005 | |
212 | #define BANDRICH_PRODUCT_1006 0x1006 | |
213 | #define BANDRICH_PRODUCT_1007 0x1007 | |
214 | #define BANDRICH_PRODUCT_1008 0x1008 | |
215 | #define BANDRICH_PRODUCT_1009 0x1009 | |
216 | #define BANDRICH_PRODUCT_100A 0x100a | |
217 | ||
218 | #define BANDRICH_PRODUCT_100B 0x100b | |
219 | #define BANDRICH_PRODUCT_100C 0x100c | |
220 | #define BANDRICH_PRODUCT_100D 0x100d | |
221 | #define BANDRICH_PRODUCT_100E 0x100e | |
222 | ||
223 | #define BANDRICH_PRODUCT_100F 0x100f | |
224 | #define BANDRICH_PRODUCT_1010 0x1010 | |
225 | #define BANDRICH_PRODUCT_1011 0x1011 | |
226 | #define BANDRICH_PRODUCT_1012 0x1012 | |
227 | ||
228 | #define QUALCOMM_VENDOR_ID 0x05C6 | |
229 | ||
230 | #define CMOTECH_VENDOR_ID 0x16d8 | |
231 | #define CMOTECH_PRODUCT_6008 0x6008 | |
232 | #define CMOTECH_PRODUCT_6280 0x6280 | |
233 | ||
234 | #define TELIT_VENDOR_ID 0x1bc7 | |
235 | #define TELIT_PRODUCT_UC864E 0x1003 | |
236 | #define TELIT_PRODUCT_UC864G 0x1004 | |
237 | #define TELIT_PRODUCT_CC864_DUAL 0x1005 | |
238 | #define TELIT_PRODUCT_CC864_SINGLE 0x1006 | |
239 | #define TELIT_PRODUCT_DE910_DUAL 0x1010 | |
240 | ||
241 | /* ZTE PRODUCTS */ | |
242 | #define ZTE_VENDOR_ID 0x19d2 | |
243 | #define ZTE_PRODUCT_MF622 0x0001 | |
244 | #define ZTE_PRODUCT_MF628 0x0015 | |
245 | #define ZTE_PRODUCT_MF626 0x0031 | |
246 | #define ZTE_PRODUCT_CDMA_TECH 0xfffe | |
247 | #define ZTE_PRODUCT_AC8710 0xfff1 | |
248 | #define ZTE_PRODUCT_AC2726 0xfff5 | |
249 | #define ZTE_PRODUCT_AC8710T 0xffff | |
250 | #define ZTE_PRODUCT_MC2718 0xffe8 | |
251 | #define ZTE_PRODUCT_AD3812 0xffeb | |
252 | #define ZTE_PRODUCT_MC2716 0xffed | |
253 | ||
254 | #define BENQ_VENDOR_ID 0x04a5 | |
255 | #define BENQ_PRODUCT_H10 0x4068 | |
256 | ||
257 | #define DLINK_VENDOR_ID 0x1186 | |
258 | #define DLINK_PRODUCT_DWM_652 0x3e04 | |
259 | #define DLINK_PRODUCT_DWM_652_U5 0xce16 | |
260 | #define DLINK_PRODUCT_DWM_652_U5A 0xce1e | |
261 | ||
262 | #define QISDA_VENDOR_ID 0x1da5 | |
263 | #define QISDA_PRODUCT_H21_4512 0x4512 | |
264 | #define QISDA_PRODUCT_H21_4523 0x4523 | |
265 | #define QISDA_PRODUCT_H20_4515 0x4515 | |
266 | #define QISDA_PRODUCT_H20_4518 0x4518 | |
267 | #define QISDA_PRODUCT_H20_4519 0x4519 | |
268 | ||
269 | /* TLAYTECH PRODUCTS */ | |
270 | #define TLAYTECH_VENDOR_ID 0x20B9 | |
271 | #define TLAYTECH_PRODUCT_TEU800 0x1682 | |
272 | ||
273 | /* TOSHIBA PRODUCTS */ | |
274 | #define TOSHIBA_VENDOR_ID 0x0930 | |
275 | #define TOSHIBA_PRODUCT_HSDPA_MINICARD 0x1302 | |
276 | #define TOSHIBA_PRODUCT_G450 0x0d45 | |
277 | ||
278 | #define ALINK_VENDOR_ID 0x1e0e | |
279 | #define ALINK_PRODUCT_PH300 0x9100 | |
280 | #define ALINK_PRODUCT_3GU 0x9200 | |
281 | ||
282 | /* ALCATEL PRODUCTS */ | |
283 | #define ALCATEL_VENDOR_ID 0x1bbb | |
284 | #define ALCATEL_PRODUCT_X060S_X200 0x0000 | |
285 | ||
286 | #define PIRELLI_VENDOR_ID 0x1266 | |
287 | #define PIRELLI_PRODUCT_C100_1 0x1002 | |
288 | #define PIRELLI_PRODUCT_C100_2 0x1003 | |
289 | #define PIRELLI_PRODUCT_1004 0x1004 | |
290 | #define PIRELLI_PRODUCT_1005 0x1005 | |
291 | #define PIRELLI_PRODUCT_1006 0x1006 | |
292 | #define PIRELLI_PRODUCT_1007 0x1007 | |
293 | #define PIRELLI_PRODUCT_1008 0x1008 | |
294 | #define PIRELLI_PRODUCT_1009 0x1009 | |
295 | #define PIRELLI_PRODUCT_100A 0x100a | |
296 | #define PIRELLI_PRODUCT_100B 0x100b | |
297 | #define PIRELLI_PRODUCT_100C 0x100c | |
298 | #define PIRELLI_PRODUCT_100D 0x100d | |
299 | #define PIRELLI_PRODUCT_100E 0x100e | |
300 | #define PIRELLI_PRODUCT_100F 0x100f | |
301 | #define PIRELLI_PRODUCT_1011 0x1011 | |
302 | #define PIRELLI_PRODUCT_1012 0x1012 | |
303 | ||
304 | /* Airplus products */ | |
305 | #define AIRPLUS_VENDOR_ID 0x1011 | |
306 | #define AIRPLUS_PRODUCT_MCD650 0x3198 | |
307 | ||
308 | /* Longcheer/Longsung vendor ID; makes whitelabel devices that | |
309 | * many other vendors like 4G Systems, Alcatel, ChinaBird, | |
310 | * Mobidata, etc sell under their own brand names. | |
311 | */ | |
312 | #define LONGCHEER_VENDOR_ID 0x1c9e | |
313 | ||
314 | /* 4G Systems products */ | |
315 | /* This is the 4G XS Stick W14 a.k.a. Mobilcom Debitel Surf-Stick * | |
316 | * It seems to contain a Qualcomm QSC6240/6290 chipset */ | |
317 | #define FOUR_G_SYSTEMS_PRODUCT_W14 0x9603 | |
318 | ||
319 | /* Zoom */ | |
320 | #define ZOOM_PRODUCT_4597 0x9607 | |
321 | ||
322 | /* Haier products */ | |
323 | #define HAIER_VENDOR_ID 0x201e | |
324 | #define HAIER_PRODUCT_CE100 0x2009 | |
325 | ||
326 | /* Cinterion (formerly Siemens) products */ | |
327 | #define SIEMENS_VENDOR_ID 0x0681 | |
328 | #define CINTERION_VENDOR_ID 0x1e2d | |
329 | #define CINTERION_PRODUCT_HC25_MDM 0x0047 | |
330 | #define CINTERION_PRODUCT_HC25_MDMNET 0x0040 | |
331 | #define CINTERION_PRODUCT_HC28_MDM 0x004C | |
332 | #define CINTERION_PRODUCT_HC28_MDMNET 0x004A /* same for HC28J */ | |
333 | #define CINTERION_PRODUCT_EU3_E 0x0051 | |
334 | #define CINTERION_PRODUCT_EU3_P 0x0052 | |
335 | #define CINTERION_PRODUCT_PH8 0x0053 | |
336 | ||
337 | /* Olivetti products */ | |
338 | #define OLIVETTI_VENDOR_ID 0x0b3c | |
339 | #define OLIVETTI_PRODUCT_OLICARD100 0xc000 | |
340 | ||
341 | /* Celot products */ | |
342 | #define CELOT_VENDOR_ID 0x211f | |
343 | #define CELOT_PRODUCT_CT680M 0x6801 | |
344 | ||
345 | /* ONDA Communication vendor id */ | |
346 | #define ONDA_VENDOR_ID 0x1ee8 | |
347 | ||
348 | /* ONDA MT825UP HSDPA 14.2 modem */ | |
349 | #define ONDA_MT825UP 0x000b | |
350 | ||
351 | /* Samsung products */ | |
352 | #define SAMSUNG_VENDOR_ID 0x04e8 | |
353 | #define SAMSUNG_PRODUCT_GT_B3730 0x6889 | |
354 | ||
355 | /* YUGA products www.yuga-info.com gavin.kx@qq.com */ | |
356 | #define YUGA_VENDOR_ID 0x257A | |
357 | #define YUGA_PRODUCT_CEM600 0x1601 | |
358 | #define YUGA_PRODUCT_CEM610 0x1602 | |
359 | #define YUGA_PRODUCT_CEM500 0x1603 | |
360 | #define YUGA_PRODUCT_CEM510 0x1604 | |
361 | #define YUGA_PRODUCT_CEM800 0x1605 | |
362 | #define YUGA_PRODUCT_CEM900 0x1606 | |
363 | ||
364 | #define YUGA_PRODUCT_CEU818 0x1607 | |
365 | #define YUGA_PRODUCT_CEU816 0x1608 | |
366 | #define YUGA_PRODUCT_CEU828 0x1609 | |
367 | #define YUGA_PRODUCT_CEU826 0x160A | |
368 | #define YUGA_PRODUCT_CEU518 0x160B | |
369 | #define YUGA_PRODUCT_CEU516 0x160C | |
370 | #define YUGA_PRODUCT_CEU528 0x160D | |
371 | #define YUGA_PRODUCT_CEU526 0x160F | |
372 | #define YUGA_PRODUCT_CEU881 0x161F | |
373 | #define YUGA_PRODUCT_CEU882 0x162F | |
374 | ||
375 | #define YUGA_PRODUCT_CWM600 0x2601 | |
376 | #define YUGA_PRODUCT_CWM610 0x2602 | |
377 | #define YUGA_PRODUCT_CWM500 0x2603 | |
378 | #define YUGA_PRODUCT_CWM510 0x2604 | |
379 | #define YUGA_PRODUCT_CWM800 0x2605 | |
380 | #define YUGA_PRODUCT_CWM900 0x2606 | |
381 | ||
382 | #define YUGA_PRODUCT_CWU718 0x2607 | |
383 | #define YUGA_PRODUCT_CWU716 0x2608 | |
384 | #define YUGA_PRODUCT_CWU728 0x2609 | |
385 | #define YUGA_PRODUCT_CWU726 0x260A | |
386 | #define YUGA_PRODUCT_CWU518 0x260B | |
387 | #define YUGA_PRODUCT_CWU516 0x260C | |
388 | #define YUGA_PRODUCT_CWU528 0x260D | |
389 | #define YUGA_PRODUCT_CWU581 0x260E | |
390 | #define YUGA_PRODUCT_CWU526 0x260F | |
391 | #define YUGA_PRODUCT_CWU582 0x261F | |
392 | #define YUGA_PRODUCT_CWU583 0x262F | |
393 | ||
394 | #define YUGA_PRODUCT_CLM600 0x3601 | |
395 | #define YUGA_PRODUCT_CLM610 0x3602 | |
396 | #define YUGA_PRODUCT_CLM500 0x3603 | |
397 | #define YUGA_PRODUCT_CLM510 0x3604 | |
398 | #define YUGA_PRODUCT_CLM800 0x3605 | |
399 | #define YUGA_PRODUCT_CLM900 0x3606 | |
400 | ||
401 | #define YUGA_PRODUCT_CLU718 0x3607 | |
402 | #define YUGA_PRODUCT_CLU716 0x3608 | |
403 | #define YUGA_PRODUCT_CLU728 0x3609 | |
404 | #define YUGA_PRODUCT_CLU726 0x360A | |
405 | #define YUGA_PRODUCT_CLU518 0x360B | |
406 | #define YUGA_PRODUCT_CLU516 0x360C | |
407 | #define YUGA_PRODUCT_CLU528 0x360D | |
408 | #define YUGA_PRODUCT_CLU526 0x360F | |
409 | ||
410 | /* Viettel products */ | |
411 | #define VIETTEL_VENDOR_ID 0x2262 | |
412 | #define VIETTEL_PRODUCT_VT1000 0x0002 | |
413 | ||
414 | /* ZD Incorporated */ | |
415 | #define ZD_VENDOR_ID 0x0685 | |
416 | #define ZD_PRODUCT_7000 0x7000 | |
417 | ||
418 | /* LG products */ | |
419 | #define LG_VENDOR_ID 0x1004 | |
420 | #define LG_PRODUCT_L02C 0x618f | |
421 | ||
422 | /* MediaTek products */ | |
423 | #define MEDIATEK_VENDOR_ID 0x0e8d | |
424 | #define MEDIATEK_PRODUCT_DC_1COM 0x00a0 | |
425 | #define MEDIATEK_PRODUCT_DC_4COM 0x00a5 | |
426 | #define MEDIATEK_PRODUCT_DC_5COM 0x00a4 | |
427 | #define MEDIATEK_PRODUCT_7208_1COM 0x7101 | |
428 | #define MEDIATEK_PRODUCT_7208_2COM 0x7102 | |
429 | #define MEDIATEK_PRODUCT_FP_1COM 0x0003 | |
430 | #define MEDIATEK_PRODUCT_FP_2COM 0x0023 | |
431 | #define MEDIATEK_PRODUCT_FPDC_1COM 0x0043 | |
432 | #define MEDIATEK_PRODUCT_FPDC_2COM 0x0033 | |
433 | ||
434 | /* Cellient products */ | |
435 | #define CELLIENT_VENDOR_ID 0x2692 | |
436 | #define CELLIENT_PRODUCT_MEN200 0x9005 | |
437 | ||
438 | /* some devices interfaces need special handling due to a number of reasons */ | |
439 | enum option_blacklist_reason { | |
440 | OPTION_BLACKLIST_NONE = 0, | |
441 | OPTION_BLACKLIST_SENDSETUP = 1, | |
442 | OPTION_BLACKLIST_RESERVED_IF = 2 | |
443 | }; | |
444 | ||
445 | #define MAX_BL_NUM 8 | |
446 | struct option_blacklist_info { | |
447 | /* bitfield of interface numbers for OPTION_BLACKLIST_SENDSETUP */ | |
448 | const unsigned long sendsetup; | |
449 | /* bitfield of interface numbers for OPTION_BLACKLIST_RESERVED_IF */ | |
450 | const unsigned long reserved; | |
451 | }; | |
452 | ||
453 | static const struct option_blacklist_info four_g_w14_blacklist = { | |
454 | .sendsetup = BIT(0) | BIT(1), | |
455 | }; | |
456 | ||
457 | static const struct option_blacklist_info alcatel_x200_blacklist = { | |
458 | .sendsetup = BIT(0) | BIT(1), | |
459 | }; | |
460 | ||
461 | static const struct option_blacklist_info zte_0037_blacklist = { | |
462 | .sendsetup = BIT(0) | BIT(1), | |
463 | }; | |
464 | ||
465 | static const struct option_blacklist_info zte_k3765_z_blacklist = { | |
466 | .sendsetup = BIT(0) | BIT(1) | BIT(2), | |
467 | .reserved = BIT(4), | |
468 | }; | |
469 | ||
470 | static const struct option_blacklist_info zte_ad3812_z_blacklist = { | |
471 | .sendsetup = BIT(0) | BIT(1) | BIT(2), | |
472 | }; | |
473 | ||
474 | static const struct option_blacklist_info zte_mc2718_z_blacklist = { | |
475 | .sendsetup = BIT(1) | BIT(2) | BIT(3) | BIT(4), | |
476 | }; | |
477 | ||
478 | static const struct option_blacklist_info zte_mc2716_z_blacklist = { | |
479 | .sendsetup = BIT(1) | BIT(2) | BIT(3), | |
480 | }; | |
481 | ||
482 | static const struct option_blacklist_info huawei_cdc12_blacklist = { | |
483 | .reserved = BIT(1) | BIT(2), | |
484 | }; | |
485 | ||
486 | static const struct option_blacklist_info net_intf1_blacklist = { | |
487 | .reserved = BIT(1), | |
488 | }; | |
489 | ||
490 | static const struct option_blacklist_info net_intf2_blacklist = { | |
491 | .reserved = BIT(2), | |
492 | }; | |
493 | ||
494 | static const struct option_blacklist_info net_intf3_blacklist = { | |
495 | .reserved = BIT(3), | |
496 | }; | |
497 | ||
498 | static const struct option_blacklist_info net_intf4_blacklist = { | |
499 | .reserved = BIT(4), | |
500 | }; | |
501 | ||
502 | static const struct option_blacklist_info net_intf5_blacklist = { | |
503 | .reserved = BIT(5), | |
504 | }; | |
505 | ||
506 | static const struct option_blacklist_info net_intf6_blacklist = { | |
507 | .reserved = BIT(6), | |
508 | }; | |
509 | ||
510 | static const struct option_blacklist_info zte_mf626_blacklist = { | |
511 | .sendsetup = BIT(0) | BIT(1), | |
512 | .reserved = BIT(4), | |
513 | }; | |
514 | ||
515 | static const struct option_blacklist_info zte_1255_blacklist = { | |
516 | .reserved = BIT(3) | BIT(4), | |
517 | }; | |
518 | ||
519 | static const struct usb_device_id option_ids[] = { | |
520 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COLT) }, | |
521 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA) }, | |
522 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_LIGHT) }, | |
523 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_QUAD) }, | |
524 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_QUAD_LIGHT) }, | |
525 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_NDIS) }, | |
526 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_NDIS_LIGHT) }, | |
527 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_NDIS_QUAD) }, | |
528 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_NDIS_QUAD_LIGHT) }, | |
529 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COBRA) }, | |
530 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COBRA_BUS) }, | |
531 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_VIPER) }, | |
532 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_VIPER_BUS) }, | |
533 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_GT_MAX_READY) }, | |
534 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_FUJI_MODEM_LIGHT) }, | |
535 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_FUJI_MODEM_GT) }, | |
536 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_FUJI_MODEM_EX) }, | |
537 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_KOI_MODEM) }, | |
538 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_SCORPION_MODEM) }, | |
539 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_ETNA_MODEM) }, | |
540 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_ETNA_MODEM_LITE) }, | |
541 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_ETNA_MODEM_GT) }, | |
542 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_ETNA_MODEM_EX) }, | |
543 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_ETNA_KOI_MODEM) }, | |
544 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_GTM380_MODEM) }, | |
545 | { USB_DEVICE(QUANTA_VENDOR_ID, QUANTA_PRODUCT_Q101) }, | |
546 | { USB_DEVICE(QUANTA_VENDOR_ID, QUANTA_PRODUCT_Q111) }, | |
547 | { USB_DEVICE(QUANTA_VENDOR_ID, QUANTA_PRODUCT_GLX) }, | |
548 | { USB_DEVICE(QUANTA_VENDOR_ID, QUANTA_PRODUCT_GKE) }, | |
549 | { USB_DEVICE(QUANTA_VENDOR_ID, QUANTA_PRODUCT_GLE) }, | |
550 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K4505, 0xff, 0xff, 0xff), | |
551 | .driver_info = (kernel_ulong_t) &huawei_cdc12_blacklist }, | |
552 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3765, 0xff, 0xff, 0xff), | |
553 | .driver_info = (kernel_ulong_t) &huawei_cdc12_blacklist }, | |
554 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K4605, 0xff, 0xff, 0xff), | |
555 | .driver_info = (kernel_ulong_t) &huawei_cdc12_blacklist }, | |
556 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0xff, 0xff) }, | |
557 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x01) }, | |
558 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x02) }, | |
559 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x03) }, | |
560 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x04) }, | |
561 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x05) }, | |
562 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x06) }, | |
563 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x0A) }, | |
564 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x0B) }, | |
565 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x0D) }, | |
566 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x0E) }, | |
567 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x0F) }, | |
568 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x10) }, | |
569 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x12) }, | |
570 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x13) }, | |
571 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x14) }, | |
572 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x15) }, | |
573 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x17) }, | |
574 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x18) }, | |
575 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x19) }, | |
576 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x1A) }, | |
577 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x1B) }, | |
578 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x1C) }, | |
579 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x31) }, | |
580 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x32) }, | |
581 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x33) }, | |
582 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x34) }, | |
583 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x35) }, | |
584 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x36) }, | |
585 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x3A) }, | |
586 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x3B) }, | |
587 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x3D) }, | |
588 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x3E) }, | |
589 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x3F) }, | |
590 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x48) }, | |
591 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x49) }, | |
592 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x4A) }, | |
593 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x4B) }, | |
594 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x4C) }, | |
595 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x61) }, | |
596 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x62) }, | |
597 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x63) }, | |
598 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x64) }, | |
599 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x65) }, | |
600 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x66) }, | |
601 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x6A) }, | |
602 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x6B) }, | |
603 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x6D) }, | |
604 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x6E) }, | |
605 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x6F) }, | |
606 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x78) }, | |
607 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x79) }, | |
608 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x7A) }, | |
609 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x7B) }, | |
610 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x01, 0x7C) }, | |
611 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x01) }, | |
612 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x02) }, | |
613 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x03) }, | |
614 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x04) }, | |
615 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x05) }, | |
616 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x06) }, | |
617 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x0A) }, | |
618 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x0B) }, | |
619 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x0D) }, | |
620 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x0E) }, | |
621 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x0F) }, | |
622 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x10) }, | |
623 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x12) }, | |
624 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x13) }, | |
625 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x14) }, | |
626 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x15) }, | |
627 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x17) }, | |
628 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x18) }, | |
629 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x19) }, | |
630 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x1A) }, | |
631 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x1B) }, | |
632 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x1C) }, | |
633 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x31) }, | |
634 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x32) }, | |
635 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x33) }, | |
636 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x34) }, | |
637 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x35) }, | |
638 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x36) }, | |
639 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x3A) }, | |
640 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x3B) }, | |
641 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x3D) }, | |
642 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x3E) }, | |
643 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x3F) }, | |
644 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x48) }, | |
645 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x49) }, | |
646 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x4A) }, | |
647 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x4B) }, | |
648 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x4C) }, | |
649 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x61) }, | |
650 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x62) }, | |
651 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x63) }, | |
652 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x64) }, | |
653 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x65) }, | |
654 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x66) }, | |
655 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x6A) }, | |
656 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x6B) }, | |
657 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x6D) }, | |
658 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x6E) }, | |
659 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x6F) }, | |
660 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x78) }, | |
661 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x79) }, | |
662 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x7A) }, | |
663 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x7B) }, | |
664 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x02, 0x7C) }, | |
665 | ||
666 | ||
667 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V640) }, | |
668 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V620) }, | |
669 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V740) }, | |
670 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V720) }, | |
671 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U730) }, | |
672 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U740) }, | |
673 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U870) }, | |
674 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_XU870) }, | |
675 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_X950D) }, | |
676 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EV620) }, | |
677 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_ES720) }, | |
678 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_E725) }, | |
679 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_ES620) }, | |
680 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU730) }, | |
681 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU740) }, | |
682 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU870D) }, | |
683 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC950D) }, | |
684 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727) }, | |
685 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_OVMC760) }, | |
686 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC780) }, | |
687 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_FULLSPEED) }, | |
688 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_FULLSPEED) }, | |
689 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_EMBEDDED_FULLSPEED) }, | |
690 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_EMBEDDED_FULLSPEED) }, | |
691 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_HIGHSPEED) }, | |
692 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED) }, | |
693 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED3) }, | |
694 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED4) }, | |
695 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED5) }, | |
696 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED6) }, | |
697 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED7) }, | |
698 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC996D) }, | |
699 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MF3470) }, | |
700 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC547) }, | |
701 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_EMBEDDED_HIGHSPEED) }, | |
702 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_EMBEDDED_HIGHSPEED) }, | |
703 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_G1) }, | |
704 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_G1_M) }, | |
705 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_G2) }, | |
706 | /* Novatel Ovation MC551 a.k.a. Verizon USB551L */ | |
707 | { USB_DEVICE_AND_INTERFACE_INFO(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC551, 0xff, 0xff, 0xff) }, | |
708 | ||
709 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01) }, | |
710 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01A) }, | |
711 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H02) }, | |
712 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_SKYPEPHONE_S2) }, | |
713 | ||
714 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5700_MINICARD) }, /* Dell Wireless 5700 Mobile Broadband CDMA/EVDO Mini-Card == Novatel Expedite EV620 CDMA/EV-DO */ | |
715 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5500_MINICARD) }, /* Dell Wireless 5500 Mobile Broadband HSDPA Mini-Card == Novatel Expedite EU740 HSDPA/3G */ | |
716 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5505_MINICARD) }, /* Dell Wireless 5505 Mobile Broadband HSDPA Mini-Card == Novatel Expedite EU740 HSDPA/3G */ | |
717 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5700_EXPRESSCARD) }, /* Dell Wireless 5700 Mobile Broadband CDMA/EVDO ExpressCard == Novatel Merlin XV620 CDMA/EV-DO */ | |
718 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5510_EXPRESSCARD) }, /* Dell Wireless 5510 Mobile Broadband HSDPA ExpressCard == Novatel Merlin XU870 HSDPA/3G */ | |
719 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5700_MINICARD_SPRINT) }, /* Dell Wireless 5700 Mobile Broadband CDMA/EVDO Mini-Card == Novatel Expedite E720 CDMA/EV-DO */ | |
720 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5700_MINICARD_TELUS) }, /* Dell Wireless 5700 Mobile Broadband CDMA/EVDO Mini-Card == Novatel Expedite ET620 CDMA/EV-DO */ | |
721 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5720_MINICARD_VZW) }, /* Dell Wireless 5720 == Novatel EV620 CDMA/EV-DO */ | |
722 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5720_MINICARD_SPRINT) }, /* Dell Wireless 5720 == Novatel EV620 CDMA/EV-DO */ | |
723 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5720_MINICARD_TELUS) }, /* Dell Wireless 5720 == Novatel EV620 CDMA/EV-DO */ | |
724 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5520_MINICARD_CINGULAR) }, /* Dell Wireless HSDPA 5520 == Novatel Expedite EU860D */ | |
725 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5520_MINICARD_GENERIC_L) }, /* Dell Wireless HSDPA 5520 */ | |
726 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5520_MINICARD_GENERIC_I) }, /* Dell Wireless 5520 Voda I Mobile Broadband (3G HSDPA) Minicard */ | |
727 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5730_MINICARD_SPRINT) }, /* Dell Wireless 5730 Mobile Broadband EVDO/HSPA Mini-Card */ | |
728 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5730_MINICARD_TELUS) }, /* Dell Wireless 5730 Mobile Broadband EVDO/HSPA Mini-Card */ | |
729 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5730_MINICARD_VZW) }, /* Dell Wireless 5730 Mobile Broadband EVDO/HSPA Mini-Card */ | |
730 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_E100A) }, /* ADU-E100, ADU-310 */ | |
731 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_500A) }, | |
732 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_620UW) }, | |
733 | { USB_DEVICE(AXESSTEL_VENDOR_ID, AXESSTEL_PRODUCT_MV110H) }, | |
734 | { USB_DEVICE(YISO_VENDOR_ID, YISO_PRODUCT_U893) }, | |
735 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_1, 0xff) }, | |
736 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_2, 0xff) }, | |
737 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1004, 0xff) }, | |
738 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1005, 0xff) }, | |
739 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1006, 0xff) }, | |
740 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1007, 0xff) }, | |
741 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1008, 0xff) }, | |
742 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1009, 0xff) }, | |
743 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_100A, 0xff) }, | |
744 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_100B, 0xff) }, | |
745 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_100C, 0xff) }, | |
746 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_100D, 0xff) }, | |
747 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_100E, 0xff) }, | |
748 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_100F, 0xff) }, | |
749 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1010, 0xff) }, | |
750 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1011, 0xff) }, | |
751 | { USB_DEVICE_INTERFACE_CLASS(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_1012, 0xff) }, | |
752 | { USB_DEVICE(KYOCERA_VENDOR_ID, KYOCERA_PRODUCT_KPC650) }, | |
753 | { USB_DEVICE(KYOCERA_VENDOR_ID, KYOCERA_PRODUCT_KPC680) }, | |
754 | { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x6000)}, /* ZTE AC8700 */ | |
755 | { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x6613)}, /* Onda H600/ZTE MF330 */ | |
756 | { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x9000)}, /* SIMCom SIM5218 */ | |
757 | { USB_DEVICE(CMOTECH_VENDOR_ID, CMOTECH_PRODUCT_6280) }, /* BP3-USB & BP3-EXT HSDPA */ | |
758 | { USB_DEVICE(CMOTECH_VENDOR_ID, CMOTECH_PRODUCT_6008) }, | |
759 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UC864E) }, | |
760 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UC864G) }, | |
761 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_CC864_DUAL) }, | |
762 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_CC864_SINGLE) }, | |
763 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_DE910_DUAL) }, | |
764 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF622, 0xff, 0xff, 0xff) }, /* ZTE WCDMA products */ | |
765 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0002, 0xff, 0xff, 0xff), | |
766 | .driver_info = (kernel_ulong_t)&net_intf1_blacklist }, | |
767 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0003, 0xff, 0xff, 0xff) }, | |
768 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0004, 0xff, 0xff, 0xff) }, | |
769 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0005, 0xff, 0xff, 0xff) }, | |
770 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0006, 0xff, 0xff, 0xff) }, | |
771 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0008, 0xff, 0xff, 0xff) }, | |
772 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0009, 0xff, 0xff, 0xff) }, | |
773 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000a, 0xff, 0xff, 0xff) }, | |
774 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000b, 0xff, 0xff, 0xff) }, | |
775 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000c, 0xff, 0xff, 0xff) }, | |
776 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000d, 0xff, 0xff, 0xff) }, | |
777 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000e, 0xff, 0xff, 0xff) }, | |
778 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000f, 0xff, 0xff, 0xff) }, | |
779 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0010, 0xff, 0xff, 0xff) }, | |
780 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0011, 0xff, 0xff, 0xff) }, | |
781 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0012, 0xff, 0xff, 0xff), | |
782 | .driver_info = (kernel_ulong_t)&net_intf1_blacklist }, | |
783 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0013, 0xff, 0xff, 0xff) }, | |
784 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF628, 0xff, 0xff, 0xff) }, | |
785 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0016, 0xff, 0xff, 0xff) }, | |
786 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0017, 0xff, 0xff, 0xff), | |
787 | .driver_info = (kernel_ulong_t)&net_intf3_blacklist }, | |
788 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0018, 0xff, 0xff, 0xff) }, | |
789 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0019, 0xff, 0xff, 0xff) }, | |
790 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0020, 0xff, 0xff, 0xff) }, | |
791 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0021, 0xff, 0xff, 0xff), | |
792 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
793 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0022, 0xff, 0xff, 0xff) }, | |
794 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0023, 0xff, 0xff, 0xff) }, | |
795 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0024, 0xff, 0xff, 0xff) }, | |
796 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0025, 0xff, 0xff, 0xff), | |
797 | .driver_info = (kernel_ulong_t)&net_intf1_blacklist }, | |
798 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0028, 0xff, 0xff, 0xff) }, | |
799 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0029, 0xff, 0xff, 0xff) }, | |
800 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0030, 0xff, 0xff, 0xff) }, | |
801 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF626, 0xff, | |
802 | 0xff, 0xff), .driver_info = (kernel_ulong_t)&zte_mf626_blacklist }, | |
803 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0032, 0xff, 0xff, 0xff) }, | |
804 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0033, 0xff, 0xff, 0xff) }, | |
805 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0034, 0xff, 0xff, 0xff) }, | |
806 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0037, 0xff, 0xff, 0xff), | |
807 | .driver_info = (kernel_ulong_t)&zte_0037_blacklist }, | |
808 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0038, 0xff, 0xff, 0xff) }, | |
809 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0039, 0xff, 0xff, 0xff) }, | |
810 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0040, 0xff, 0xff, 0xff) }, | |
811 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0042, 0xff, 0xff, 0xff), | |
812 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
813 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0043, 0xff, 0xff, 0xff) }, | |
814 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0044, 0xff, 0xff, 0xff) }, | |
815 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0048, 0xff, 0xff, 0xff) }, | |
816 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0049, 0xff, 0xff, 0xff), | |
817 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
818 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0050, 0xff, 0xff, 0xff) }, | |
819 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0051, 0xff, 0xff, 0xff) }, | |
820 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0052, 0xff, 0xff, 0xff), | |
821 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
822 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0054, 0xff, 0xff, 0xff) }, | |
823 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0055, 0xff, 0xff, 0xff), | |
824 | .driver_info = (kernel_ulong_t)&net_intf1_blacklist }, | |
825 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0056, 0xff, 0xff, 0xff) }, | |
826 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0057, 0xff, 0xff, 0xff) }, | |
827 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0058, 0xff, 0xff, 0xff), | |
828 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
829 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0061, 0xff, 0xff, 0xff) }, | |
830 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0062, 0xff, 0xff, 0xff) }, | |
831 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0063, 0xff, 0xff, 0xff), | |
832 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
833 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0064, 0xff, 0xff, 0xff) }, | |
834 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0065, 0xff, 0xff, 0xff) }, | |
835 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0066, 0xff, 0xff, 0xff) }, | |
836 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0067, 0xff, 0xff, 0xff) }, | |
837 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0069, 0xff, 0xff, 0xff) }, | |
838 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0076, 0xff, 0xff, 0xff) }, | |
839 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0077, 0xff, 0xff, 0xff) }, | |
840 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0078, 0xff, 0xff, 0xff) }, | |
841 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0079, 0xff, 0xff, 0xff) }, | |
842 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0082, 0xff, 0xff, 0xff) }, | |
843 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0083, 0xff, 0xff, 0xff) }, | |
844 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0086, 0xff, 0xff, 0xff) }, | |
845 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0087, 0xff, 0xff, 0xff) }, | |
846 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0088, 0xff, 0xff, 0xff) }, | |
847 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0089, 0xff, 0xff, 0xff) }, | |
848 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0090, 0xff, 0xff, 0xff) }, | |
849 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0091, 0xff, 0xff, 0xff) }, | |
850 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0092, 0xff, 0xff, 0xff) }, | |
851 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0093, 0xff, 0xff, 0xff) }, | |
852 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0094, 0xff, 0xff, 0xff) }, | |
853 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0095, 0xff, 0xff, 0xff) }, | |
854 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0096, 0xff, 0xff, 0xff) }, | |
855 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0097, 0xff, 0xff, 0xff) }, | |
856 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0104, 0xff, 0xff, 0xff), | |
857 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
858 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0105, 0xff, 0xff, 0xff) }, | |
859 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0106, 0xff, 0xff, 0xff) }, | |
860 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0108, 0xff, 0xff, 0xff) }, | |
861 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0113, 0xff, 0xff, 0xff), | |
862 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
863 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0117, 0xff, 0xff, 0xff) }, | |
864 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0118, 0xff, 0xff, 0xff), | |
865 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
866 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0121, 0xff, 0xff, 0xff), | |
867 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
868 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0122, 0xff, 0xff, 0xff) }, | |
869 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0123, 0xff, 0xff, 0xff), | |
870 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
871 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0124, 0xff, 0xff, 0xff), | |
872 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
873 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0125, 0xff, 0xff, 0xff), | |
874 | .driver_info = (kernel_ulong_t)&net_intf6_blacklist }, | |
875 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0126, 0xff, 0xff, 0xff), | |
876 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
877 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0128, 0xff, 0xff, 0xff) }, | |
878 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0142, 0xff, 0xff, 0xff) }, | |
879 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0143, 0xff, 0xff, 0xff) }, | |
880 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0144, 0xff, 0xff, 0xff) }, | |
881 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0145, 0xff, 0xff, 0xff) }, | |
882 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0148, 0xff, 0xff, 0xff) }, | |
883 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0151, 0xff, 0xff, 0xff) }, | |
884 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0153, 0xff, 0xff, 0xff) }, | |
885 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0155, 0xff, 0xff, 0xff) }, | |
886 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0156, 0xff, 0xff, 0xff) }, | |
887 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0157, 0xff, 0xff, 0xff), | |
888 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
889 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0158, 0xff, 0xff, 0xff), | |
890 | .driver_info = (kernel_ulong_t)&net_intf3_blacklist }, | |
891 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0159, 0xff, 0xff, 0xff) }, | |
892 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0161, 0xff, 0xff, 0xff) }, | |
893 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0162, 0xff, 0xff, 0xff) }, | |
894 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0164, 0xff, 0xff, 0xff) }, | |
895 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0165, 0xff, 0xff, 0xff) }, | |
896 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0167, 0xff, 0xff, 0xff), | |
897 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
898 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0191, 0xff, 0xff, 0xff), /* ZTE EuFi890 */ | |
899 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
900 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0199, 0xff, 0xff, 0xff), /* ZTE MF820S */ | |
901 | .driver_info = (kernel_ulong_t)&net_intf1_blacklist }, | |
902 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0257, 0xff, 0xff, 0xff), /* ZTE MF821 */ | |
903 | .driver_info = (kernel_ulong_t)&net_intf3_blacklist }, | |
904 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0326, 0xff, 0xff, 0xff), | |
905 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
906 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1008, 0xff, 0xff, 0xff), | |
907 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
908 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1010, 0xff, 0xff, 0xff), | |
909 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
910 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1012, 0xff, 0xff, 0xff), | |
911 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
912 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1021, 0xff, 0xff, 0xff), | |
913 | .driver_info = (kernel_ulong_t)&net_intf2_blacklist }, | |
914 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1057, 0xff, 0xff, 0xff) }, | |
915 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1058, 0xff, 0xff, 0xff) }, | |
916 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1059, 0xff, 0xff, 0xff) }, | |
917 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1060, 0xff, 0xff, 0xff) }, | |
918 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1061, 0xff, 0xff, 0xff) }, | |
919 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1062, 0xff, 0xff, 0xff) }, | |
920 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1063, 0xff, 0xff, 0xff) }, | |
921 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1064, 0xff, 0xff, 0xff) }, | |
922 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1065, 0xff, 0xff, 0xff) }, | |
923 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1066, 0xff, 0xff, 0xff) }, | |
924 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1067, 0xff, 0xff, 0xff) }, | |
925 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1068, 0xff, 0xff, 0xff) }, | |
926 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1069, 0xff, 0xff, 0xff) }, | |
927 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1070, 0xff, 0xff, 0xff) }, | |
928 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1071, 0xff, 0xff, 0xff) }, | |
929 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1072, 0xff, 0xff, 0xff) }, | |
930 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1073, 0xff, 0xff, 0xff) }, | |
931 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1074, 0xff, 0xff, 0xff) }, | |
932 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1075, 0xff, 0xff, 0xff) }, | |
933 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1076, 0xff, 0xff, 0xff) }, | |
934 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1077, 0xff, 0xff, 0xff) }, | |
935 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1078, 0xff, 0xff, 0xff) }, | |
936 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1079, 0xff, 0xff, 0xff) }, | |
937 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1080, 0xff, 0xff, 0xff) }, | |
938 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1081, 0xff, 0xff, 0xff) }, | |
939 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1082, 0xff, 0xff, 0xff) }, | |
940 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1083, 0xff, 0xff, 0xff) }, | |
941 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1084, 0xff, 0xff, 0xff) }, | |
942 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1085, 0xff, 0xff, 0xff) }, | |
943 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1086, 0xff, 0xff, 0xff) }, | |
944 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1087, 0xff, 0xff, 0xff) }, | |
945 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1088, 0xff, 0xff, 0xff) }, | |
946 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1089, 0xff, 0xff, 0xff) }, | |
947 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1090, 0xff, 0xff, 0xff) }, | |
948 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1091, 0xff, 0xff, 0xff) }, | |
949 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1092, 0xff, 0xff, 0xff) }, | |
950 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1093, 0xff, 0xff, 0xff) }, | |
951 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1094, 0xff, 0xff, 0xff) }, | |
952 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1095, 0xff, 0xff, 0xff) }, | |
953 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1096, 0xff, 0xff, 0xff) }, | |
954 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1097, 0xff, 0xff, 0xff) }, | |
955 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1098, 0xff, 0xff, 0xff) }, | |
956 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1099, 0xff, 0xff, 0xff) }, | |
957 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1100, 0xff, 0xff, 0xff) }, | |
958 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1101, 0xff, 0xff, 0xff) }, | |
959 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1102, 0xff, 0xff, 0xff) }, | |
960 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1103, 0xff, 0xff, 0xff) }, | |
961 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1104, 0xff, 0xff, 0xff) }, | |
962 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1105, 0xff, 0xff, 0xff) }, | |
963 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1106, 0xff, 0xff, 0xff) }, | |
964 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1107, 0xff, 0xff, 0xff) }, | |
965 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1108, 0xff, 0xff, 0xff) }, | |
966 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1109, 0xff, 0xff, 0xff) }, | |
967 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1110, 0xff, 0xff, 0xff) }, | |
968 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1111, 0xff, 0xff, 0xff) }, | |
969 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1112, 0xff, 0xff, 0xff) }, | |
970 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1113, 0xff, 0xff, 0xff) }, | |
971 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1114, 0xff, 0xff, 0xff) }, | |
972 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1115, 0xff, 0xff, 0xff) }, | |
973 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1116, 0xff, 0xff, 0xff) }, | |
974 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1117, 0xff, 0xff, 0xff) }, | |
975 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1118, 0xff, 0xff, 0xff) }, | |
976 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1119, 0xff, 0xff, 0xff) }, | |
977 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1120, 0xff, 0xff, 0xff) }, | |
978 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1121, 0xff, 0xff, 0xff) }, | |
979 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1122, 0xff, 0xff, 0xff) }, | |
980 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1123, 0xff, 0xff, 0xff) }, | |
981 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1124, 0xff, 0xff, 0xff) }, | |
982 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1125, 0xff, 0xff, 0xff) }, | |
983 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1126, 0xff, 0xff, 0xff) }, | |
984 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1127, 0xff, 0xff, 0xff) }, | |
985 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1128, 0xff, 0xff, 0xff) }, | |
986 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1129, 0xff, 0xff, 0xff) }, | |
987 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1130, 0xff, 0xff, 0xff) }, | |
988 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1131, 0xff, 0xff, 0xff) }, | |
989 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1132, 0xff, 0xff, 0xff) }, | |
990 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1133, 0xff, 0xff, 0xff) }, | |
991 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1134, 0xff, 0xff, 0xff) }, | |
992 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1135, 0xff, 0xff, 0xff) }, | |
993 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1136, 0xff, 0xff, 0xff) }, | |
994 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1137, 0xff, 0xff, 0xff) }, | |
995 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1138, 0xff, 0xff, 0xff) }, | |
996 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1139, 0xff, 0xff, 0xff) }, | |
997 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1140, 0xff, 0xff, 0xff) }, | |
998 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1141, 0xff, 0xff, 0xff) }, | |
999 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1142, 0xff, 0xff, 0xff) }, | |
1000 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1143, 0xff, 0xff, 0xff) }, | |
1001 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1144, 0xff, 0xff, 0xff) }, | |
1002 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1145, 0xff, 0xff, 0xff) }, | |
1003 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1146, 0xff, 0xff, 0xff) }, | |
1004 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1147, 0xff, 0xff, 0xff) }, | |
1005 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1148, 0xff, 0xff, 0xff) }, | |
1006 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1149, 0xff, 0xff, 0xff) }, | |
1007 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1150, 0xff, 0xff, 0xff) }, | |
1008 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1151, 0xff, 0xff, 0xff) }, | |
1009 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1152, 0xff, 0xff, 0xff) }, | |
1010 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1153, 0xff, 0xff, 0xff) }, | |
1011 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1154, 0xff, 0xff, 0xff) }, | |
1012 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1155, 0xff, 0xff, 0xff) }, | |
1013 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1156, 0xff, 0xff, 0xff) }, | |
1014 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1157, 0xff, 0xff, 0xff) }, | |
1015 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1158, 0xff, 0xff, 0xff) }, | |
1016 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1159, 0xff, 0xff, 0xff) }, | |
1017 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1160, 0xff, 0xff, 0xff) }, | |
1018 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1161, 0xff, 0xff, 0xff) }, | |
1019 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1162, 0xff, 0xff, 0xff) }, | |
1020 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1163, 0xff, 0xff, 0xff) }, | |
1021 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1164, 0xff, 0xff, 0xff) }, | |
1022 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1165, 0xff, 0xff, 0xff) }, | |
1023 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1166, 0xff, 0xff, 0xff) }, | |
1024 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1167, 0xff, 0xff, 0xff) }, | |
1025 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1168, 0xff, 0xff, 0xff) }, | |
1026 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1169, 0xff, 0xff, 0xff) }, | |
1027 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1170, 0xff, 0xff, 0xff) }, | |
1028 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1244, 0xff, 0xff, 0xff) }, | |
1029 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1245, 0xff, 0xff, 0xff), | |
1030 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
1031 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1246, 0xff, 0xff, 0xff) }, | |
1032 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1247, 0xff, 0xff, 0xff), | |
1033 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
1034 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1248, 0xff, 0xff, 0xff) }, | |
1035 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1249, 0xff, 0xff, 0xff) }, | |
1036 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1250, 0xff, 0xff, 0xff) }, | |
1037 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1251, 0xff, 0xff, 0xff) }, | |
1038 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1252, 0xff, 0xff, 0xff), | |
1039 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
1040 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1253, 0xff, 0xff, 0xff) }, | |
1041 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1254, 0xff, 0xff, 0xff), | |
1042 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
1043 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1255, 0xff, 0xff, 0xff), | |
1044 | .driver_info = (kernel_ulong_t)&zte_1255_blacklist }, | |
1045 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1256, 0xff, 0xff, 0xff), | |
1046 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
1047 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1257, 0xff, 0xff, 0xff) }, | |
1048 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1258, 0xff, 0xff, 0xff) }, | |
1049 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1259, 0xff, 0xff, 0xff) }, | |
1050 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1260, 0xff, 0xff, 0xff) }, | |
1051 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1261, 0xff, 0xff, 0xff) }, | |
1052 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1262, 0xff, 0xff, 0xff) }, | |
1053 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1263, 0xff, 0xff, 0xff) }, | |
1054 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1264, 0xff, 0xff, 0xff) }, | |
1055 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1265, 0xff, 0xff, 0xff) }, | |
1056 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1266, 0xff, 0xff, 0xff) }, | |
1057 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1267, 0xff, 0xff, 0xff) }, | |
1058 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1268, 0xff, 0xff, 0xff) }, | |
1059 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1269, 0xff, 0xff, 0xff) }, | |
1060 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1270, 0xff, 0xff, 0xff) }, | |
1061 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1271, 0xff, 0xff, 0xff) }, | |
1062 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1272, 0xff, 0xff, 0xff) }, | |
1063 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1273, 0xff, 0xff, 0xff) }, | |
1064 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1274, 0xff, 0xff, 0xff) }, | |
1065 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1275, 0xff, 0xff, 0xff) }, | |
1066 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1276, 0xff, 0xff, 0xff) }, | |
1067 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1277, 0xff, 0xff, 0xff) }, | |
1068 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1278, 0xff, 0xff, 0xff) }, | |
1069 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1279, 0xff, 0xff, 0xff) }, | |
1070 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1280, 0xff, 0xff, 0xff) }, | |
1071 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1281, 0xff, 0xff, 0xff) }, | |
1072 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1282, 0xff, 0xff, 0xff) }, | |
1073 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1283, 0xff, 0xff, 0xff) }, | |
1074 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1284, 0xff, 0xff, 0xff) }, | |
1075 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1285, 0xff, 0xff, 0xff) }, | |
1076 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1286, 0xff, 0xff, 0xff) }, | |
1077 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1287, 0xff, 0xff, 0xff) }, | |
1078 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1288, 0xff, 0xff, 0xff) }, | |
1079 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1289, 0xff, 0xff, 0xff) }, | |
1080 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1290, 0xff, 0xff, 0xff) }, | |
1081 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1291, 0xff, 0xff, 0xff) }, | |
1082 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1292, 0xff, 0xff, 0xff) }, | |
1083 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1293, 0xff, 0xff, 0xff) }, | |
1084 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1294, 0xff, 0xff, 0xff) }, | |
1085 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1295, 0xff, 0xff, 0xff) }, | |
1086 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1296, 0xff, 0xff, 0xff) }, | |
1087 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1297, 0xff, 0xff, 0xff) }, | |
1088 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1298, 0xff, 0xff, 0xff) }, | |
1089 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1299, 0xff, 0xff, 0xff) }, | |
1090 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1300, 0xff, 0xff, 0xff) }, | |
1091 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1401, 0xff, 0xff, 0xff), | |
1092 | .driver_info = (kernel_ulong_t)&net_intf2_blacklist }, | |
1093 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1402, 0xff, 0xff, 0xff), | |
1094 | .driver_info = (kernel_ulong_t)&net_intf2_blacklist }, | |
1095 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1424, 0xff, 0xff, 0xff), | |
1096 | .driver_info = (kernel_ulong_t)&net_intf2_blacklist }, | |
1097 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1425, 0xff, 0xff, 0xff), | |
1098 | .driver_info = (kernel_ulong_t)&net_intf2_blacklist }, | |
1099 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1426, 0xff, 0xff, 0xff), /* ZTE MF91 */ | |
1100 | .driver_info = (kernel_ulong_t)&net_intf2_blacklist }, | |
1101 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x2002, 0xff, | |
1102 | 0xff, 0xff), .driver_info = (kernel_ulong_t)&zte_k3765_z_blacklist }, | |
1103 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x2003, 0xff, 0xff, 0xff) }, | |
1104 | ||
1105 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0014, 0xff, 0xff, 0xff) }, /* ZTE CDMA products */ | |
1106 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0027, 0xff, 0xff, 0xff) }, | |
1107 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0059, 0xff, 0xff, 0xff) }, | |
1108 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0060, 0xff, 0xff, 0xff) }, | |
1109 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0070, 0xff, 0xff, 0xff) }, | |
1110 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0073, 0xff, 0xff, 0xff) }, | |
1111 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0094, 0xff, 0xff, 0xff) }, | |
1112 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0130, 0xff, 0xff, 0xff), | |
1113 | .driver_info = (kernel_ulong_t)&net_intf1_blacklist }, | |
1114 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0133, 0xff, 0xff, 0xff), | |
1115 | .driver_info = (kernel_ulong_t)&net_intf3_blacklist }, | |
1116 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0141, 0xff, 0xff, 0xff), | |
1117 | .driver_info = (kernel_ulong_t)&net_intf5_blacklist }, | |
1118 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0147, 0xff, 0xff, 0xff) }, | |
1119 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0152, 0xff, 0xff, 0xff) }, | |
1120 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0168, 0xff, 0xff, 0xff), | |
1121 | .driver_info = (kernel_ulong_t)&net_intf4_blacklist }, | |
1122 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0170, 0xff, 0xff, 0xff) }, | |
1123 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0176, 0xff, 0xff, 0xff), | |
1124 | .driver_info = (kernel_ulong_t)&net_intf3_blacklist }, | |
1125 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0178, 0xff, 0xff, 0xff), | |
1126 | .driver_info = (kernel_ulong_t)&net_intf3_blacklist }, | |
1127 | ||
1128 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_CDMA_TECH, 0xff, 0xff, 0xff) }, | |
1129 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_AC8710, 0xff, 0xff, 0xff) }, | |
1130 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_AC2726, 0xff, 0xff, 0xff) }, | |
1131 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_AC8710T, 0xff, 0xff, 0xff) }, | |
1132 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MC2718, 0xff, 0xff, 0xff), | |
1133 | .driver_info = (kernel_ulong_t)&zte_mc2718_z_blacklist }, | |
1134 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_AD3812, 0xff, 0xff, 0xff), | |
1135 | .driver_info = (kernel_ulong_t)&zte_ad3812_z_blacklist }, | |
1136 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MC2716, 0xff, 0xff, 0xff), | |
1137 | .driver_info = (kernel_ulong_t)&zte_mc2716_z_blacklist }, | |
1138 | { USB_VENDOR_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0xff, 0x02, 0x01) }, | |
1139 | { USB_VENDOR_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0xff, 0x02, 0x05) }, | |
1140 | { USB_VENDOR_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0xff, 0x86, 0x10) }, | |
1141 | ||
1142 | { USB_DEVICE(BENQ_VENDOR_ID, BENQ_PRODUCT_H10) }, | |
1143 | { USB_DEVICE(DLINK_VENDOR_ID, DLINK_PRODUCT_DWM_652) }, | |
1144 | { USB_DEVICE(ALINK_VENDOR_ID, DLINK_PRODUCT_DWM_652_U5) }, /* Yes, ALINK_VENDOR_ID */ | |
1145 | { USB_DEVICE(ALINK_VENDOR_ID, DLINK_PRODUCT_DWM_652_U5A) }, | |
1146 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) }, | |
1147 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4523) }, | |
1148 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4515) }, | |
1149 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4518) }, | |
1150 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4519) }, | |
1151 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_G450) }, | |
1152 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */ | |
1153 | { USB_DEVICE(ALINK_VENDOR_ID, 0x9000) }, | |
1154 | { USB_DEVICE(ALINK_VENDOR_ID, ALINK_PRODUCT_PH300) }, | |
1155 | { USB_DEVICE_AND_INTERFACE_INFO(ALINK_VENDOR_ID, ALINK_PRODUCT_3GU, 0xff, 0xff, 0xff) }, | |
1156 | { USB_DEVICE(ALCATEL_VENDOR_ID, ALCATEL_PRODUCT_X060S_X200), | |
1157 | .driver_info = (kernel_ulong_t)&alcatel_x200_blacklist | |
1158 | }, | |
1159 | { USB_DEVICE(AIRPLUS_VENDOR_ID, AIRPLUS_PRODUCT_MCD650) }, | |
1160 | { USB_DEVICE(TLAYTECH_VENDOR_ID, TLAYTECH_PRODUCT_TEU800) }, | |
1161 | { USB_DEVICE(LONGCHEER_VENDOR_ID, FOUR_G_SYSTEMS_PRODUCT_W14), | |
1162 | .driver_info = (kernel_ulong_t)&four_g_w14_blacklist | |
1163 | }, | |
1164 | { USB_DEVICE(LONGCHEER_VENDOR_ID, ZOOM_PRODUCT_4597) }, | |
1165 | { USB_DEVICE(HAIER_VENDOR_ID, HAIER_PRODUCT_CE100) }, | |
1166 | /* Pirelli */ | |
1167 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_C100_1, 0xff) }, | |
1168 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_C100_2, 0xff) }, | |
1169 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1004, 0xff) }, | |
1170 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1005, 0xff) }, | |
1171 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1006, 0xff) }, | |
1172 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1007, 0xff) }, | |
1173 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1008, 0xff) }, | |
1174 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1009, 0xff) }, | |
1175 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_100A, 0xff) }, | |
1176 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_100B, 0xff) }, | |
1177 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_100C, 0xff) }, | |
1178 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_100D, 0xff) }, | |
1179 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_100E, 0xff) }, | |
1180 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_100F, 0xff) }, | |
1181 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1011, 0xff) }, | |
1182 | { USB_DEVICE_INTERFACE_CLASS(PIRELLI_VENDOR_ID, PIRELLI_PRODUCT_1012, 0xff) }, | |
1183 | /* Cinterion */ | |
1184 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_EU3_E) }, | |
1185 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_EU3_P) }, | |
1186 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_PH8) }, | |
1187 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_HC28_MDM) }, | |
1188 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_HC28_MDMNET) }, | |
1189 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC25_MDM) }, | |
1190 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC25_MDMNET) }, | |
1191 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC28_MDM) }, /* HC28 enumerates with Siemens or Cinterion VID depending on FW revision */ | |
1192 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC28_MDMNET) }, | |
1193 | ||
1194 | { USB_DEVICE(OLIVETTI_VENDOR_ID, OLIVETTI_PRODUCT_OLICARD100) }, | |
1195 | { USB_DEVICE(CELOT_VENDOR_ID, CELOT_PRODUCT_CT680M) }, /* CT-650 CDMA 450 1xEVDO modem */ | |
1196 | { USB_DEVICE(ONDA_VENDOR_ID, ONDA_MT825UP) }, /* ONDA MT825UP modem */ | |
1197 | { USB_DEVICE_AND_INTERFACE_INFO(SAMSUNG_VENDOR_ID, SAMSUNG_PRODUCT_GT_B3730, USB_CLASS_CDC_DATA, 0x00, 0x00) }, /* Samsung GT-B3730 LTE USB modem.*/ | |
1198 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEM600) }, | |
1199 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEM610) }, | |
1200 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEM500) }, | |
1201 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEM510) }, | |
1202 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEM800) }, | |
1203 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEM900) }, | |
1204 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU818) }, | |
1205 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU816) }, | |
1206 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU828) }, | |
1207 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU826) }, | |
1208 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU518) }, | |
1209 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU516) }, | |
1210 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU528) }, | |
1211 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU526) }, | |
1212 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWM600) }, | |
1213 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWM610) }, | |
1214 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWM500) }, | |
1215 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWM510) }, | |
1216 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWM800) }, | |
1217 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWM900) }, | |
1218 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU718) }, | |
1219 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU716) }, | |
1220 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU728) }, | |
1221 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU726) }, | |
1222 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU518) }, | |
1223 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU516) }, | |
1224 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU528) }, | |
1225 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU526) }, | |
1226 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLM600) }, | |
1227 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLM610) }, | |
1228 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLM500) }, | |
1229 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLM510) }, | |
1230 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLM800) }, | |
1231 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLM900) }, | |
1232 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU718) }, | |
1233 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU716) }, | |
1234 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU728) }, | |
1235 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU726) }, | |
1236 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU518) }, | |
1237 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU516) }, | |
1238 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU528) }, | |
1239 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CLU526) }, | |
1240 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU881) }, | |
1241 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CEU882) }, | |
1242 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU581) }, | |
1243 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU582) }, | |
1244 | { USB_DEVICE(YUGA_VENDOR_ID, YUGA_PRODUCT_CWU583) }, | |
1245 | { USB_DEVICE_AND_INTERFACE_INFO(VIETTEL_VENDOR_ID, VIETTEL_PRODUCT_VT1000, 0xff, 0xff, 0xff) }, | |
1246 | { USB_DEVICE_AND_INTERFACE_INFO(ZD_VENDOR_ID, ZD_PRODUCT_7000, 0xff, 0xff, 0xff) }, | |
1247 | { USB_DEVICE(LG_VENDOR_ID, LG_PRODUCT_L02C) }, /* docomo L-02C modem */ | |
1248 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a1, 0xff, 0x00, 0x00) }, | |
1249 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a1, 0xff, 0x02, 0x01) }, | |
1250 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a2, 0xff, 0x00, 0x00) }, | |
1251 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a2, 0xff, 0x02, 0x01) }, /* MediaTek MT6276M modem & app port */ | |
1252 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_1COM, 0x0a, 0x00, 0x00) }, | |
1253 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_5COM, 0xff, 0x02, 0x01) }, | |
1254 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_5COM, 0xff, 0x00, 0x00) }, | |
1255 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_4COM, 0xff, 0x02, 0x01) }, | |
1256 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_4COM, 0xff, 0x00, 0x00) }, | |
1257 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_7208_1COM, 0x02, 0x00, 0x00) }, | |
1258 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_7208_2COM, 0x02, 0x02, 0x01) }, | |
1259 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_FP_1COM, 0x0a, 0x00, 0x00) }, | |
1260 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_FP_2COM, 0x0a, 0x00, 0x00) }, | |
1261 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_FPDC_1COM, 0x0a, 0x00, 0x00) }, | |
1262 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_FPDC_2COM, 0x0a, 0x00, 0x00) }, | |
1263 | { USB_DEVICE(CELLIENT_VENDOR_ID, CELLIENT_PRODUCT_MEN200) }, | |
1264 | { } /* Terminating entry */ | |
1265 | }; | |
1266 | MODULE_DEVICE_TABLE(usb, option_ids); | |
1267 | ||
1268 | /* The card has three separate interfaces, which the serial driver | |
1269 | * recognizes separately, thus num_port=1. | |
1270 | */ | |
1271 | ||
1272 | static struct usb_serial_driver option_1port_device = { | |
1273 | .driver = { | |
1274 | .owner = THIS_MODULE, | |
1275 | .name = "option1", | |
1276 | }, | |
1277 | .description = "GSM modem (1-port)", | |
1278 | .id_table = option_ids, | |
1279 | .num_ports = 1, | |
1280 | .probe = option_probe, | |
1281 | .open = usb_wwan_open, | |
1282 | .close = usb_wwan_close, | |
1283 | .dtr_rts = usb_wwan_dtr_rts, | |
1284 | .write = usb_wwan_write, | |
1285 | .write_room = usb_wwan_write_room, | |
1286 | .chars_in_buffer = usb_wwan_chars_in_buffer, | |
1287 | .set_termios = usb_wwan_set_termios, | |
1288 | .tiocmget = usb_wwan_tiocmget, | |
1289 | .tiocmset = usb_wwan_tiocmset, | |
1290 | .ioctl = usb_wwan_ioctl, | |
1291 | .attach = option_attach, | |
1292 | .release = option_release, | |
1293 | .port_probe = usb_wwan_port_probe, | |
1294 | .port_remove = usb_wwan_port_remove, | |
1295 | .read_int_callback = option_instat_callback, | |
1296 | #ifdef CONFIG_PM | |
1297 | .suspend = usb_wwan_suspend, | |
1298 | .resume = usb_wwan_resume, | |
1299 | #endif | |
1300 | }; | |
1301 | ||
1302 | static struct usb_serial_driver * const serial_drivers[] = { | |
1303 | &option_1port_device, NULL | |
1304 | }; | |
1305 | ||
1306 | struct option_private { | |
1307 | u8 bInterfaceNumber; | |
1308 | }; | |
1309 | ||
1310 | module_usb_serial_driver(serial_drivers, option_ids); | |
1311 | ||
1312 | static bool is_blacklisted(const u8 ifnum, enum option_blacklist_reason reason, | |
1313 | const struct option_blacklist_info *blacklist) | |
1314 | { | |
1315 | unsigned long num; | |
1316 | const unsigned long *intf_list; | |
1317 | ||
1318 | if (blacklist) { | |
1319 | if (reason == OPTION_BLACKLIST_SENDSETUP) | |
1320 | intf_list = &blacklist->sendsetup; | |
1321 | else if (reason == OPTION_BLACKLIST_RESERVED_IF) | |
1322 | intf_list = &blacklist->reserved; | |
1323 | else { | |
1324 | BUG_ON(reason); | |
1325 | return false; | |
1326 | } | |
1327 | ||
1328 | for_each_set_bit(num, intf_list, MAX_BL_NUM + 1) { | |
1329 | if (num == ifnum) | |
1330 | return true; | |
1331 | } | |
1332 | } | |
1333 | return false; | |
1334 | } | |
1335 | ||
1336 | static int option_probe(struct usb_serial *serial, | |
1337 | const struct usb_device_id *id) | |
1338 | { | |
1339 | struct usb_interface_descriptor *iface_desc = | |
1340 | &serial->interface->cur_altsetting->desc; | |
1341 | struct usb_device_descriptor *dev_desc = &serial->dev->descriptor; | |
1342 | ||
1343 | /* Never bind to the CD-Rom emulation interface */ | |
1344 | if (iface_desc->bInterfaceClass == 0x08) | |
1345 | return -ENODEV; | |
1346 | ||
1347 | /* | |
1348 | * Don't bind reserved interfaces (like network ones) which often have | |
1349 | * the same class/subclass/protocol as the serial interfaces. Look at | |
1350 | * the Windows driver .INF files for reserved interface numbers. | |
1351 | */ | |
1352 | if (is_blacklisted( | |
1353 | iface_desc->bInterfaceNumber, | |
1354 | OPTION_BLACKLIST_RESERVED_IF, | |
1355 | (const struct option_blacklist_info *) id->driver_info)) | |
1356 | return -ENODEV; | |
1357 | /* | |
1358 | * Don't bind network interface on Samsung GT-B3730, it is handled by | |
1359 | * a separate module. | |
1360 | */ | |
1361 | if (dev_desc->idVendor == SAMSUNG_VENDOR_ID && | |
1362 | dev_desc->idProduct == SAMSUNG_PRODUCT_GT_B3730 && | |
1363 | iface_desc->bInterfaceClass != USB_CLASS_CDC_DATA) | |
1364 | return -ENODEV; | |
1365 | ||
1366 | /* Store device id so we can use it during attach. */ | |
1367 | usb_set_serial_data(serial, (void *)id); | |
1368 | ||
1369 | return 0; | |
1370 | } | |
1371 | ||
1372 | static int option_attach(struct usb_serial *serial) | |
1373 | { | |
1374 | struct usb_interface_descriptor *iface_desc; | |
1375 | const struct usb_device_id *id; | |
1376 | struct usb_wwan_intf_private *data; | |
1377 | struct option_private *priv; | |
1378 | ||
1379 | data = kzalloc(sizeof(struct usb_wwan_intf_private), GFP_KERNEL); | |
1380 | if (!data) | |
1381 | return -ENOMEM; | |
1382 | ||
1383 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); | |
1384 | if (!priv) { | |
1385 | kfree(data); | |
1386 | return -ENOMEM; | |
1387 | } | |
1388 | ||
1389 | /* Retrieve device id stored at probe. */ | |
1390 | id = usb_get_serial_data(serial); | |
1391 | iface_desc = &serial->interface->cur_altsetting->desc; | |
1392 | ||
1393 | priv->bInterfaceNumber = iface_desc->bInterfaceNumber; | |
1394 | data->private = priv; | |
1395 | ||
1396 | if (!is_blacklisted(iface_desc->bInterfaceNumber, | |
1397 | OPTION_BLACKLIST_SENDSETUP, | |
1398 | (struct option_blacklist_info *)id->driver_info)) { | |
1399 | data->send_setup = option_send_setup; | |
1400 | } | |
1401 | spin_lock_init(&data->susp_lock); | |
1402 | ||
1403 | usb_set_serial_data(serial, data); | |
1404 | ||
1405 | return 0; | |
1406 | } | |
1407 | ||
1408 | static void option_release(struct usb_serial *serial) | |
1409 | { | |
1410 | struct usb_wwan_intf_private *intfdata = usb_get_serial_data(serial); | |
1411 | struct option_private *priv = intfdata->private; | |
1412 | ||
1413 | kfree(priv); | |
1414 | kfree(intfdata); | |
1415 | } | |
1416 | ||
1417 | static void option_instat_callback(struct urb *urb) | |
1418 | { | |
1419 | int err; | |
1420 | int status = urb->status; | |
1421 | struct usb_serial_port *port = urb->context; | |
1422 | struct device *dev = &port->dev; | |
1423 | struct usb_wwan_port_private *portdata = | |
1424 | usb_get_serial_port_data(port); | |
1425 | ||
1426 | dev_dbg(dev, "%s: urb %p port %p has data %p\n", __func__, urb, port, portdata); | |
1427 | ||
1428 | if (status == 0) { | |
1429 | struct usb_ctrlrequest *req_pkt = | |
1430 | (struct usb_ctrlrequest *)urb->transfer_buffer; | |
1431 | ||
1432 | if (!req_pkt) { | |
1433 | dev_dbg(dev, "%s: NULL req_pkt\n", __func__); | |
1434 | return; | |
1435 | } | |
1436 | if ((req_pkt->bRequestType == 0xA1) && | |
1437 | (req_pkt->bRequest == 0x20)) { | |
1438 | int old_dcd_state; | |
1439 | unsigned char signals = *((unsigned char *) | |
1440 | urb->transfer_buffer + | |
1441 | sizeof(struct usb_ctrlrequest)); | |
1442 | ||
1443 | dev_dbg(dev, "%s: signal x%x\n", __func__, signals); | |
1444 | ||
1445 | old_dcd_state = portdata->dcd_state; | |
1446 | portdata->cts_state = 1; | |
1447 | portdata->dcd_state = ((signals & 0x01) ? 1 : 0); | |
1448 | portdata->dsr_state = ((signals & 0x02) ? 1 : 0); | |
1449 | portdata->ri_state = ((signals & 0x08) ? 1 : 0); | |
1450 | ||
1451 | if (old_dcd_state && !portdata->dcd_state) { | |
1452 | struct tty_struct *tty = | |
1453 | tty_port_tty_get(&port->port); | |
1454 | if (tty && !C_CLOCAL(tty)) | |
1455 | tty_hangup(tty); | |
1456 | tty_kref_put(tty); | |
1457 | } | |
1458 | } else { | |
1459 | dev_dbg(dev, "%s: type %x req %x\n", __func__, | |
1460 | req_pkt->bRequestType, req_pkt->bRequest); | |
1461 | } | |
1462 | } else | |
1463 | dev_err(dev, "%s: error %d\n", __func__, status); | |
1464 | ||
1465 | /* Resubmit urb so we continue receiving IRQ data */ | |
1466 | if (status != -ESHUTDOWN && status != -ENOENT) { | |
1467 | err = usb_submit_urb(urb, GFP_ATOMIC); | |
1468 | if (err) | |
1469 | dev_dbg(dev, "%s: resubmit intr urb failed. (%d)\n", | |
1470 | __func__, err); | |
1471 | } | |
1472 | } | |
1473 | ||
1474 | /** send RTS/DTR state to the port. | |
1475 | * | |
1476 | * This is exactly the same as SET_CONTROL_LINE_STATE from the PSTN | |
1477 | * CDC. | |
1478 | */ | |
1479 | static int option_send_setup(struct usb_serial_port *port) | |
1480 | { | |
1481 | struct usb_serial *serial = port->serial; | |
1482 | struct usb_wwan_intf_private *intfdata = usb_get_serial_data(serial); | |
1483 | struct option_private *priv = intfdata->private; | |
1484 | struct usb_wwan_port_private *portdata; | |
1485 | int val = 0; | |
1486 | ||
1487 | portdata = usb_get_serial_port_data(port); | |
1488 | ||
1489 | if (portdata->dtr_state) | |
1490 | val |= 0x01; | |
1491 | if (portdata->rts_state) | |
1492 | val |= 0x02; | |
1493 | ||
1494 | return usb_control_msg(serial->dev, usb_rcvctrlpipe(serial->dev, 0), | |
1495 | 0x22, 0x21, val, priv->bInterfaceNumber, NULL, | |
1496 | 0, USB_CTRL_SET_TIMEOUT); | |
1497 | } | |
1498 | ||
1499 | MODULE_AUTHOR(DRIVER_AUTHOR); | |
1500 | MODULE_DESCRIPTION(DRIVER_DESC); | |
1501 | MODULE_LICENSE("GPL"); |