.. | .. |
---|
197 | 197 | #define DELL_PRODUCT_5804_MINICARD_ATT 0x819b /* Novatel E371 */ |
---|
198 | 198 | |
---|
199 | 199 | #define DELL_PRODUCT_5821E 0x81d7 |
---|
200 | | -#define DELL_PRODUCT_5821E_ESIM 0x81e0 |
---|
201 | | -#define DELL_PRODUCT_5829E_ESIM 0x81e4 |
---|
202 | | -#define DELL_PRODUCT_5829E 0x81e6 |
---|
203 | 200 | |
---|
204 | 201 | #define KYOCERA_VENDOR_ID 0x0c88 |
---|
205 | 202 | #define KYOCERA_PRODUCT_KPC650 0x17da |
---|
.. | .. |
---|
240 | 237 | #define QUECTEL_PRODUCT_UC15 0x9090 |
---|
241 | 238 | /* These u-blox products use Qualcomm's vendor ID */ |
---|
242 | 239 | #define UBLOX_PRODUCT_R410M 0x90b2 |
---|
243 | | -#define UBLOX_PRODUCT_R6XX 0x90fa |
---|
244 | 240 | /* These Yuga products use Qualcomm's vendor ID */ |
---|
245 | 241 | #define YUGA_PRODUCT_CLM920_NC5 0x9625 |
---|
246 | 242 | |
---|
.. | .. |
---|
248 | 244 | /* These Quectel products use Quectel's vendor ID */ |
---|
249 | 245 | #define QUECTEL_PRODUCT_EC21 0x0121 |
---|
250 | 246 | #define QUECTEL_PRODUCT_EC25 0x0125 |
---|
251 | | -#define QUECTEL_PRODUCT_EG91 0x0191 |
---|
252 | | -#define QUECTEL_PRODUCT_EG95 0x0195 |
---|
253 | 247 | #define QUECTEL_PRODUCT_BG96 0x0296 |
---|
254 | 248 | #define QUECTEL_PRODUCT_EP06 0x0306 |
---|
255 | 249 | #define QUECTEL_PRODUCT_EM12 0x0512 |
---|
256 | | -#define QUECTEL_PRODUCT_RM500Q 0x0800 |
---|
257 | | -#define QUECTEL_PRODUCT_EC200S_CN 0x6002 |
---|
258 | | -#define QUECTEL_PRODUCT_EC200T 0x6026 |
---|
259 | 250 | |
---|
260 | 251 | #define CMOTECH_VENDOR_ID 0x16d8 |
---|
261 | 252 | #define CMOTECH_PRODUCT_6001 0x6001 |
---|
.. | .. |
---|
424 | 415 | #define CINTERION_PRODUCT_PH8 0x0053 |
---|
425 | 416 | #define CINTERION_PRODUCT_AHXX 0x0055 |
---|
426 | 417 | #define CINTERION_PRODUCT_PLXX 0x0060 |
---|
427 | | -#define CINTERION_PRODUCT_EXS82 0x006c |
---|
428 | 418 | #define CINTERION_PRODUCT_PH8_2RMNET 0x0082 |
---|
429 | 419 | #define CINTERION_PRODUCT_PH8_AUDIO 0x0083 |
---|
430 | 420 | #define CINTERION_PRODUCT_AHXX_2RMNET 0x0084 |
---|
431 | 421 | #define CINTERION_PRODUCT_AHXX_AUDIO 0x0085 |
---|
432 | | -#define CINTERION_PRODUCT_CLS8 0x00b0 |
---|
433 | | -#define CINTERION_PRODUCT_MV31_MBIM 0x00b3 |
---|
434 | | -#define CINTERION_PRODUCT_MV31_RMNET 0x00b7 |
---|
435 | 422 | |
---|
436 | 423 | /* Olivetti products */ |
---|
437 | 424 | #define OLIVETTI_VENDOR_ID 0x0b3c |
---|
.. | .. |
---|
537 | 524 | /* Cellient products */ |
---|
538 | 525 | #define CELLIENT_VENDOR_ID 0x2692 |
---|
539 | 526 | #define CELLIENT_PRODUCT_MEN200 0x9005 |
---|
540 | | -#define CELLIENT_PRODUCT_MPL200 0x9025 |
---|
541 | 527 | |
---|
542 | 528 | /* Hyundai Petatel Inc. products */ |
---|
543 | 529 | #define PETATEL_VENDOR_ID 0x1ff4 |
---|
.. | .. |
---|
570 | 556 | |
---|
571 | 557 | /* Device flags */ |
---|
572 | 558 | |
---|
573 | | -/* Highest interface number which can be used with NCTRL() and RSVD() */ |
---|
574 | | -#define FLAG_IFNUM_MAX 7 |
---|
575 | | - |
---|
576 | 559 | /* Interface does not support modem-control requests */ |
---|
577 | 560 | #define NCTRL(ifnum) ((BIT(ifnum) & 0xff) << 8) |
---|
578 | 561 | |
---|
.. | .. |
---|
582 | 565 | /* Interface must have two endpoints */ |
---|
583 | 566 | #define NUMEP2 BIT(16) |
---|
584 | 567 | |
---|
585 | | -/* Device needs ZLP */ |
---|
586 | | -#define ZLP BIT(17) |
---|
587 | | - |
---|
588 | 568 | |
---|
589 | 569 | static const struct usb_device_id option_ids[] = { |
---|
590 | | - { USB_DEVICE(0x1286, 0x4e3c) }, |
---|
| 570 | +#if 1 //Added by Quectel |
---|
| 571 | + { USB_DEVICE(0x05C6, 0x9090) }, /* Quectel UC15 */ |
---|
| 572 | + { USB_DEVICE(0x05C6, 0x9003) }, /* Quectel UC20 */ |
---|
| 573 | + { USB_DEVICE(0x05C6, 0x9215) }, /* Quectel EC20(MDM9215) */ |
---|
| 574 | + { USB_DEVICE(0x2C7C, 0x0125) }, /* Quectel EC20(MDM9x07)/EC25/EG25 */ |
---|
| 575 | + { USB_DEVICE(0x2C7C, 0x0121) }, /* Quectel EC21 */ |
---|
| 576 | + { USB_DEVICE(0x2C7C, 0x0191) }, /* Quectel EG91 */ |
---|
| 577 | + { USB_DEVICE(0x2C7C, 0x0195) }, /* Quectel EG95 */ |
---|
| 578 | + { USB_DEVICE(0x2C7C, 0x0306) }, /* Quectel EG06/EP06/EM06 */ |
---|
| 579 | + { USB_DEVICE(0x2C7C, 0x030B) }, /* Quectel EG065K/EG060K */ |
---|
| 580 | + { USB_DEVICE(0x2C7C, 0x0514) }, /* Quectel BL EG060K RNDIS Only */ |
---|
| 581 | + { USB_DEVICE(0x2C7C, 0x0512) }, /* Quectel EG12/EP12/EM12/EG16/EG18 */ |
---|
| 582 | + { USB_DEVICE(0x2C7C, 0x0296) }, /* Quectel BG96 */ |
---|
| 583 | + { USB_DEVICE(0x2C7C, 0x0700) }, /* Quectel BG95/BG77/BG600L-M3/BC69 */ |
---|
| 584 | + { USB_DEVICE(0x2C7C, 0x0435) }, /* Quectel AG35 */ |
---|
| 585 | + { USB_DEVICE(0x2C7C, 0x0415) }, /* Quectel AG15 */ |
---|
| 586 | + { USB_DEVICE(0x2C7C, 0x0452) }, /* Quectel AG520 */ |
---|
| 587 | + { USB_DEVICE(0x2C7C, 0x0455) }, /* Quectel AG550 */ |
---|
| 588 | + { USB_DEVICE(0x2C7C, 0x0620) }, /* Quectel EG20 */ |
---|
| 589 | + { USB_DEVICE(0x2C7C, 0x0800) }, /* Quectel RG500/RM500/RG510/RM510 */ |
---|
| 590 | + { USB_DEVICE(0x2C7C, 0x0801) }, /* Quectel RG520/RM520/SG520 */ |
---|
| 591 | + { USB_DEVICE(0x2C7C, 0x6026) }, /* Quectel EC200 */ |
---|
| 592 | + { USB_DEVICE(0x2C7C, 0x6120) }, /* Quectel UC200 */ |
---|
| 593 | + { USB_DEVICE(0x2C7C, 0x6000) }, /* Quectel EC200/UC200 */ |
---|
| 594 | + { .match_flags = USB_DEVICE_ID_MATCH_VENDOR, .idVendor = 0x2C7C }, /* Match All Quectel Modules */ |
---|
| 595 | +#endif |
---|
591 | 596 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COLT) }, |
---|
592 | 597 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA) }, |
---|
593 | 598 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA_LIGHT) }, |
---|
.. | .. |
---|
989 | 994 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x06, 0x7B) }, |
---|
990 | 995 | { USB_VENDOR_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, 0xff, 0x06, 0x7C) }, |
---|
991 | 996 | |
---|
992 | | - /* Motorola devices */ |
---|
993 | | - { USB_DEVICE_AND_INTERFACE_INFO(0x22b8, 0x2a70, 0xff, 0xff, 0xff) }, /* mdm6600 */ |
---|
994 | | - { USB_DEVICE_AND_INTERFACE_INFO(0x22b8, 0x2e0a, 0xff, 0xff, 0xff) }, /* mdm9600 */ |
---|
995 | | - { USB_DEVICE_AND_INTERFACE_INFO(0x22b8, 0x4281, 0x0a, 0x00, 0xfc) }, /* mdm ram dl */ |
---|
996 | | - { USB_DEVICE_AND_INTERFACE_INFO(0x22b8, 0x900e, 0xff, 0xff, 0xff) }, /* mdm qc dl */ |
---|
997 | 997 | |
---|
998 | 998 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V640) }, |
---|
999 | 999 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V620) }, |
---|
.. | .. |
---|
1064 | 1064 | { USB_DEVICE_AND_INTERFACE_INFO(DELL_VENDOR_ID, DELL_PRODUCT_5804_MINICARD_ATT, 0xff, 0xff, 0xff) }, |
---|
1065 | 1065 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5821E), |
---|
1066 | 1066 | .driver_info = RSVD(0) | RSVD(1) | RSVD(6) }, |
---|
1067 | | - { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5821E_ESIM), |
---|
1068 | | - .driver_info = RSVD(0) | RSVD(1) | RSVD(6) }, |
---|
1069 | | - { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5829E), |
---|
1070 | | - .driver_info = RSVD(0) | RSVD(6) }, |
---|
1071 | | - { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5829E_ESIM), |
---|
1072 | | - .driver_info = RSVD(0) | RSVD(6) }, |
---|
1073 | 1067 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_E100A) }, /* ADU-E100, ADU-310 */ |
---|
1074 | 1068 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_500A) }, |
---|
1075 | 1069 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_620UW) }, |
---|
.. | .. |
---|
1111 | 1105 | /* u-blox products using Qualcomm vendor ID */ |
---|
1112 | 1106 | { USB_DEVICE(QUALCOMM_VENDOR_ID, UBLOX_PRODUCT_R410M), |
---|
1113 | 1107 | .driver_info = RSVD(1) | RSVD(3) }, |
---|
1114 | | - { USB_DEVICE(QUALCOMM_VENDOR_ID, UBLOX_PRODUCT_R6XX), |
---|
1115 | | - .driver_info = RSVD(3) }, |
---|
1116 | 1108 | /* Quectel products using Quectel vendor ID */ |
---|
1117 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC21, 0xff, 0xff, 0xff), |
---|
1118 | | - .driver_info = NUMEP2 }, |
---|
1119 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC21, 0xff, 0, 0) }, |
---|
1120 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC25, 0xff, 0xff, 0xff), |
---|
1121 | | - .driver_info = NUMEP2 }, |
---|
1122 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC25, 0xff, 0, 0) }, |
---|
1123 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EG91, 0xff, 0xff, 0xff), |
---|
1124 | | - .driver_info = NUMEP2 }, |
---|
1125 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EG91, 0xff, 0, 0) }, |
---|
1126 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EG95, 0xff, 0xff, 0xff), |
---|
1127 | | - .driver_info = NUMEP2 }, |
---|
1128 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EG95, 0xff, 0, 0) }, |
---|
| 1109 | + { USB_DEVICE(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC21), |
---|
| 1110 | + .driver_info = RSVD(4) }, |
---|
| 1111 | + { USB_DEVICE(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC25), |
---|
| 1112 | + .driver_info = RSVD(4) }, |
---|
1129 | 1113 | { USB_DEVICE(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_BG96), |
---|
1130 | 1114 | .driver_info = RSVD(4) }, |
---|
1131 | 1115 | { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EP06, 0xff, 0xff, 0xff), |
---|
.. | .. |
---|
1134 | 1118 | { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EM12, 0xff, 0xff, 0xff), |
---|
1135 | 1119 | .driver_info = RSVD(1) | RSVD(2) | RSVD(3) | RSVD(4) | NUMEP2 }, |
---|
1136 | 1120 | { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EM12, 0xff, 0, 0) }, |
---|
1137 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, 0x0620, 0xff, 0xff, 0x30) }, /* EM160R-GL */ |
---|
1138 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, 0x0620, 0xff, 0, 0) }, |
---|
1139 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_RM500Q, 0xff, 0xff, 0x30) }, |
---|
1140 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_RM500Q, 0xff, 0, 0) }, |
---|
1141 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_RM500Q, 0xff, 0xff, 0x10), |
---|
1142 | | - .driver_info = ZLP }, |
---|
1143 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC200S_CN, 0xff, 0, 0) }, |
---|
1144 | | - { USB_DEVICE_AND_INTERFACE_INFO(QUECTEL_VENDOR_ID, QUECTEL_PRODUCT_EC200T, 0xff, 0, 0) }, |
---|
1145 | | - |
---|
1146 | 1121 | { USB_DEVICE(CMOTECH_VENDOR_ID, CMOTECH_PRODUCT_6001) }, |
---|
1147 | 1122 | { USB_DEVICE(CMOTECH_VENDOR_ID, CMOTECH_PRODUCT_CMU_300) }, |
---|
1148 | 1123 | { USB_DEVICE(CMOTECH_VENDOR_ID, CMOTECH_PRODUCT_6003), |
---|
.. | .. |
---|
1190 | 1165 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_CC864_SINGLE) }, |
---|
1191 | 1166 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_DE910_DUAL) }, |
---|
1192 | 1167 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UE910_V2) }, |
---|
1193 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1031, 0xff), /* Telit LE910C1-EUX */ |
---|
1194 | | - .driver_info = NCTRL(0) | RSVD(3) }, |
---|
1195 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1033, 0xff), /* Telit LE910C1-EUX (ECM) */ |
---|
1196 | | - .driver_info = NCTRL(0) }, |
---|
1197 | 1168 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_LE922_USBCFG0), |
---|
1198 | 1169 | .driver_info = RSVD(0) | RSVD(1) | NCTRL(2) | RSVD(3) }, |
---|
1199 | 1170 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_LE922_USBCFG1), |
---|
.. | .. |
---|
1204 | 1175 | .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) | RSVD(3) }, |
---|
1205 | 1176 | { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, TELIT_PRODUCT_LE922_USBCFG5, 0xff), |
---|
1206 | 1177 | .driver_info = RSVD(0) | RSVD(1) | NCTRL(2) | RSVD(3) }, |
---|
1207 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1050, 0xff), /* Telit FN980 (rmnet) */ |
---|
1208 | | - .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1209 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1051, 0xff), /* Telit FN980 (MBIM) */ |
---|
1210 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1211 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1052, 0xff), /* Telit FN980 (RNDIS) */ |
---|
1212 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1213 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1053, 0xff), /* Telit FN980 (ECM) */ |
---|
1214 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1215 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1054, 0xff), /* Telit FT980-KS */ |
---|
1216 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1217 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1055, 0xff), /* Telit FN980 (PCIe) */ |
---|
1218 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1219 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1056, 0xff), /* Telit FD980 */ |
---|
1220 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1221 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1060, 0xff), /* Telit LN920 (rmnet) */ |
---|
1222 | | - .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1223 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1061, 0xff), /* Telit LN920 (MBIM) */ |
---|
1224 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1225 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1062, 0xff), /* Telit LN920 (RNDIS) */ |
---|
1226 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1227 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1063, 0xff), /* Telit LN920 (ECM) */ |
---|
1228 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1229 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1070, 0xff), /* Telit FN990 (rmnet) */ |
---|
1230 | | - .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1231 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1071, 0xff), /* Telit FN990 (MBIM) */ |
---|
1232 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1233 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1072, 0xff), /* Telit FN990 (RNDIS) */ |
---|
1234 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1235 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1073, 0xff), /* Telit FN990 (ECM) */ |
---|
1236 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1237 | 1178 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_ME910), |
---|
1238 | 1179 | .driver_info = NCTRL(0) | RSVD(1) | RSVD(3) }, |
---|
1239 | 1180 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_ME910_DUAL_MODEM), |
---|
1240 | 1181 | .driver_info = NCTRL(0) | RSVD(3) }, |
---|
1241 | 1182 | { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1102, 0xff), /* Telit ME910 (ECM) */ |
---|
1242 | 1183 | .driver_info = NCTRL(0) }, |
---|
1243 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x110a, 0xff), /* Telit ME910G1 */ |
---|
1244 | | - .driver_info = NCTRL(0) | RSVD(3) }, |
---|
1245 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x110b, 0xff), /* Telit ME910G1 (ECM) */ |
---|
1246 | | - .driver_info = NCTRL(0) }, |
---|
1247 | 1184 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_LE910), |
---|
1248 | 1185 | .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1249 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1203, 0xff), /* Telit LE910Cx (RNDIS) */ |
---|
1250 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1251 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1204, 0xff), /* Telit LE910Cx (MBIM) */ |
---|
1252 | | - .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1253 | 1186 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_LE910_USBCFG4), |
---|
1254 | 1187 | .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) | RSVD(3) }, |
---|
1255 | 1188 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_LE920), |
---|
.. | .. |
---|
1264 | 1197 | { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, TELIT_PRODUCT_LE920A4_1213, 0xff) }, |
---|
1265 | 1198 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_LE920A4_1214), |
---|
1266 | 1199 | .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) | RSVD(3) }, |
---|
1267 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1230, 0xff), /* Telit LE910Cx (rmnet) */ |
---|
1268 | | - .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1269 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1231, 0xff), /* Telit LE910Cx (RNDIS) */ |
---|
1270 | | - .driver_info = NCTRL(2) | RSVD(3) }, |
---|
1271 | | - { USB_DEVICE(TELIT_VENDOR_ID, 0x1260), |
---|
1272 | | - .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1273 | | - { USB_DEVICE(TELIT_VENDOR_ID, 0x1261), |
---|
1274 | | - .driver_info = NCTRL(0) | RSVD(1) | RSVD(2) }, |
---|
1275 | 1200 | { USB_DEVICE(TELIT_VENDOR_ID, 0x1900), /* Telit LN940 (QMI) */ |
---|
1276 | 1201 | .driver_info = NCTRL(0) | RSVD(1) }, |
---|
1277 | 1202 | { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x1901, 0xff), /* Telit LN940 (MBIM) */ |
---|
1278 | 1203 | .driver_info = NCTRL(0) }, |
---|
1279 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x7010, 0xff), /* Telit LE910-S1 (RNDIS) */ |
---|
1280 | | - .driver_info = NCTRL(2) }, |
---|
1281 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x7011, 0xff), /* Telit LE910-S1 (ECM) */ |
---|
1282 | | - .driver_info = NCTRL(2) }, |
---|
1283 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x701a, 0xff), /* Telit LE910R1 (RNDIS) */ |
---|
1284 | | - .driver_info = NCTRL(2) }, |
---|
1285 | | - { USB_DEVICE_INTERFACE_CLASS(TELIT_VENDOR_ID, 0x701b, 0xff), /* Telit LE910R1 (ECM) */ |
---|
1286 | | - .driver_info = NCTRL(2) }, |
---|
1287 | | - { USB_DEVICE(TELIT_VENDOR_ID, 0x9010), /* Telit SBL FN980 flashing device */ |
---|
1288 | | - .driver_info = NCTRL(0) | ZLP }, |
---|
1289 | | - { USB_DEVICE(TELIT_VENDOR_ID, 0x9200), /* Telit LE910S1 flashing device */ |
---|
1290 | | - .driver_info = NCTRL(0) | ZLP }, |
---|
1291 | | - { USB_DEVICE(TELIT_VENDOR_ID, 0x9201), /* Telit LE910R1 flashing device */ |
---|
1292 | | - .driver_info = NCTRL(0) | ZLP }, |
---|
1293 | 1204 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF622, 0xff, 0xff, 0xff) }, /* ZTE WCDMA products */ |
---|
1294 | 1205 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0002, 0xff, 0xff, 0xff), |
---|
1295 | 1206 | .driver_info = RSVD(1) }, |
---|
.. | .. |
---|
1454 | 1365 | .driver_info = RSVD(4) }, |
---|
1455 | 1366 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0414, 0xff, 0xff, 0xff) }, |
---|
1456 | 1367 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0417, 0xff, 0xff, 0xff) }, |
---|
1457 | | - { USB_DEVICE_INTERFACE_CLASS(ZTE_VENDOR_ID, 0x0601, 0xff) }, /* GosunCn ZTE WeLink ME3630 (RNDIS mode) */ |
---|
1458 | 1368 | { USB_DEVICE_INTERFACE_CLASS(ZTE_VENDOR_ID, 0x0602, 0xff) }, /* GosunCn ZTE WeLink ME3630 (MBIM mode) */ |
---|
1459 | 1369 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1008, 0xff, 0xff, 0xff), |
---|
1460 | 1370 | .driver_info = RSVD(4) }, |
---|
.. | .. |
---|
1617 | 1527 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1272, 0xff, 0xff, 0xff) }, |
---|
1618 | 1528 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1273, 0xff, 0xff, 0xff) }, |
---|
1619 | 1529 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1274, 0xff, 0xff, 0xff) }, |
---|
1620 | | - { USB_DEVICE(ZTE_VENDOR_ID, 0x1275), /* ZTE P685M */ |
---|
1621 | | - .driver_info = RSVD(3) | RSVD(4) }, |
---|
| 1530 | + { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1275, 0xff, 0xff, 0xff) }, |
---|
1622 | 1531 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1276, 0xff, 0xff, 0xff) }, |
---|
1623 | 1532 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1277, 0xff, 0xff, 0xff) }, |
---|
1624 | 1533 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1278, 0xff, 0xff, 0xff) }, |
---|
.. | .. |
---|
1661 | 1570 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1428, 0xff, 0xff, 0xff), /* Telewell TW-LTE 4G v2 */ |
---|
1662 | 1571 | .driver_info = RSVD(2) }, |
---|
1663 | 1572 | { USB_DEVICE_INTERFACE_CLASS(ZTE_VENDOR_ID, 0x1476, 0xff) }, /* GosunCn ZTE WeLink ME3630 (ECM/NCM mode) */ |
---|
1664 | | - { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1481, 0xff, 0x00, 0x00) }, /* ZTE MF871A */ |
---|
1665 | | - { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1485, 0xff, 0xff, 0xff), /* ZTE MF286D */ |
---|
1666 | | - .driver_info = RSVD(5) }, |
---|
1667 | 1573 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1533, 0xff, 0xff, 0xff) }, |
---|
1668 | 1574 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1534, 0xff, 0xff, 0xff) }, |
---|
1669 | 1575 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1535, 0xff, 0xff, 0xff) }, |
---|
.. | .. |
---|
1691 | 1597 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0060, 0xff, 0xff, 0xff) }, |
---|
1692 | 1598 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0070, 0xff, 0xff, 0xff) }, |
---|
1693 | 1599 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0073, 0xff, 0xff, 0xff) }, |
---|
| 1600 | + { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0094, 0xff, 0xff, 0xff) }, |
---|
1694 | 1601 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0130, 0xff, 0xff, 0xff), |
---|
1695 | 1602 | .driver_info = RSVD(1) }, |
---|
1696 | 1603 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0133, 0xff, 0xff, 0xff), |
---|
.. | .. |
---|
1891 | 1798 | { USB_DEVICE(ALINK_VENDOR_ID, SIMCOM_PRODUCT_SIM7100E), |
---|
1892 | 1799 | .driver_info = RSVD(5) | RSVD(6) }, |
---|
1893 | 1800 | { USB_DEVICE_INTERFACE_CLASS(0x1e0e, 0x9003, 0xff) }, /* Simcom SIM7500/SIM7600 MBIM mode */ |
---|
1894 | | - { USB_DEVICE_INTERFACE_CLASS(0x1e0e, 0x9011, 0xff), /* Simcom SIM7500/SIM7600 RNDIS mode */ |
---|
1895 | | - .driver_info = RSVD(7) }, |
---|
1896 | | - { USB_DEVICE_INTERFACE_CLASS(0x1e0e, 0x9205, 0xff) }, /* Simcom SIM7070/SIM7080/SIM7090 AT+ECM mode */ |
---|
1897 | | - { USB_DEVICE_INTERFACE_CLASS(0x1e0e, 0x9206, 0xff) }, /* Simcom SIM7070/SIM7080/SIM7090 AT-only mode */ |
---|
1898 | 1801 | { USB_DEVICE(ALCATEL_VENDOR_ID, ALCATEL_PRODUCT_X060S_X200), |
---|
1899 | 1802 | .driver_info = NCTRL(0) | NCTRL(1) | RSVD(4) }, |
---|
1900 | 1803 | { USB_DEVICE(ALCATEL_VENDOR_ID, ALCATEL_PRODUCT_X220_X500D), |
---|
.. | .. |
---|
1957 | 1860 | .driver_info = RSVD(4) }, |
---|
1958 | 1861 | { USB_DEVICE_INTERFACE_CLASS(CINTERION_VENDOR_ID, CINTERION_PRODUCT_AHXX_2RMNET, 0xff) }, |
---|
1959 | 1862 | { USB_DEVICE_INTERFACE_CLASS(CINTERION_VENDOR_ID, CINTERION_PRODUCT_AHXX_AUDIO, 0xff) }, |
---|
1960 | | - { USB_DEVICE_INTERFACE_CLASS(CINTERION_VENDOR_ID, CINTERION_PRODUCT_CLS8, 0xff), |
---|
1961 | | - .driver_info = RSVD(0) | RSVD(4) }, |
---|
1962 | | - { USB_DEVICE_INTERFACE_CLASS(CINTERION_VENDOR_ID, CINTERION_PRODUCT_EXS82, 0xff) }, |
---|
1963 | 1863 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_HC28_MDM) }, |
---|
1964 | 1864 | { USB_DEVICE(CINTERION_VENDOR_ID, CINTERION_PRODUCT_HC28_MDMNET) }, |
---|
1965 | 1865 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC25_MDM) }, |
---|
1966 | 1866 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC25_MDMNET) }, |
---|
1967 | 1867 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC28_MDM) }, /* HC28 enumerates with Siemens or Cinterion VID depending on FW revision */ |
---|
1968 | 1868 | { USB_DEVICE(SIEMENS_VENDOR_ID, CINTERION_PRODUCT_HC28_MDMNET) }, |
---|
1969 | | - { USB_DEVICE_INTERFACE_CLASS(CINTERION_VENDOR_ID, CINTERION_PRODUCT_MV31_MBIM, 0xff), |
---|
1970 | | - .driver_info = RSVD(3)}, |
---|
1971 | | - { USB_DEVICE_INTERFACE_CLASS(CINTERION_VENDOR_ID, CINTERION_PRODUCT_MV31_RMNET, 0xff), |
---|
1972 | | - .driver_info = RSVD(0)}, |
---|
1973 | 1869 | { USB_DEVICE(OLIVETTI_VENDOR_ID, OLIVETTI_PRODUCT_OLICARD100), |
---|
1974 | 1870 | .driver_info = RSVD(4) }, |
---|
1975 | 1871 | { USB_DEVICE(OLIVETTI_VENDOR_ID, OLIVETTI_PRODUCT_OLICARD120), |
---|
.. | .. |
---|
2057 | 1953 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_4COM2, 0xff, 0x02, 0x01) }, |
---|
2058 | 1954 | { USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, MEDIATEK_PRODUCT_DC_4COM2, 0xff, 0x00, 0x00) }, |
---|
2059 | 1955 | { USB_DEVICE(CELLIENT_VENDOR_ID, CELLIENT_PRODUCT_MEN200) }, |
---|
2060 | | - { USB_DEVICE(CELLIENT_VENDOR_ID, CELLIENT_PRODUCT_MPL200), |
---|
2061 | | - .driver_info = RSVD(1) | RSVD(4) }, |
---|
2062 | 1956 | { USB_DEVICE(PETATEL_VENDOR_ID, PETATEL_PRODUCT_NP10T_600A) }, |
---|
2063 | 1957 | { USB_DEVICE(PETATEL_VENDOR_ID, PETATEL_PRODUCT_NP10T_600E) }, |
---|
2064 | 1958 | { USB_DEVICE_AND_INTERFACE_INFO(TPLINK_VENDOR_ID, TPLINK_PRODUCT_LTE, 0xff, 0x00, 0x00) }, /* TP-Link LTE Module */ |
---|
.. | .. |
---|
2077 | 1971 | .driver_info = RSVD(4) }, |
---|
2078 | 1972 | { USB_DEVICE_INTERFACE_CLASS(0x2001, 0x7e35, 0xff), /* D-Link DWM-222 */ |
---|
2079 | 1973 | .driver_info = RSVD(4) }, |
---|
2080 | | - { USB_DEVICE_INTERFACE_CLASS(0x2001, 0x7e3d, 0xff), /* D-Link DWM-222 A2 */ |
---|
2081 | | - .driver_info = RSVD(4) }, |
---|
2082 | 1974 | { USB_DEVICE_AND_INTERFACE_INFO(0x07d1, 0x3e01, 0xff, 0xff, 0xff) }, /* D-Link DWM-152/C1 */ |
---|
2083 | 1975 | { USB_DEVICE_AND_INTERFACE_INFO(0x07d1, 0x3e02, 0xff, 0xff, 0xff) }, /* D-Link DWM-156/C1 */ |
---|
2084 | 1976 | { USB_DEVICE_AND_INTERFACE_INFO(0x07d1, 0x7e11, 0xff, 0xff, 0xff) }, /* D-Link DWM-156/A3 */ |
---|
2085 | | - { USB_DEVICE_INTERFACE_CLASS(0x1435, 0xd191, 0xff), /* Wistron Neweb D19Q1 */ |
---|
2086 | | - .driver_info = RSVD(1) | RSVD(4) }, |
---|
2087 | | - { USB_DEVICE_INTERFACE_CLASS(0x1690, 0x7588, 0xff), /* ASKEY WWHC050 */ |
---|
2088 | | - .driver_info = RSVD(1) | RSVD(4) }, |
---|
2089 | 1977 | { USB_DEVICE_INTERFACE_CLASS(0x2020, 0x2031, 0xff), /* Olicard 600 */ |
---|
2090 | | - .driver_info = RSVD(4) }, |
---|
2091 | | - { USB_DEVICE_INTERFACE_CLASS(0x2020, 0x2033, 0xff), /* BroadMobi BM806U */ |
---|
2092 | | - .driver_info = RSVD(4) }, |
---|
2093 | | - { USB_DEVICE_INTERFACE_CLASS(0x2020, 0x2060, 0xff), /* BroadMobi BM818 */ |
---|
2094 | 1978 | .driver_info = RSVD(4) }, |
---|
2095 | 1979 | { USB_DEVICE_INTERFACE_CLASS(0x2020, 0x4000, 0xff) }, /* OLICARD300 - MT6225 */ |
---|
2096 | 1980 | { USB_DEVICE(INOVIA_VENDOR_ID, INOVIA_SEW858) }, |
---|
.. | .. |
---|
2104 | 1988 | { USB_DEVICE_AND_INTERFACE_INFO(0x03f0, 0xa31d, 0xff, 0x06, 0x13) }, |
---|
2105 | 1989 | { USB_DEVICE_AND_INTERFACE_INFO(0x03f0, 0xa31d, 0xff, 0x06, 0x14) }, |
---|
2106 | 1990 | { USB_DEVICE_AND_INTERFACE_INFO(0x03f0, 0xa31d, 0xff, 0x06, 0x1b) }, |
---|
2107 | | - { USB_DEVICE(0x0489, 0xe0b4), /* Foxconn T77W968 */ |
---|
2108 | | - .driver_info = RSVD(0) | RSVD(1) | RSVD(6) }, |
---|
2109 | | - { USB_DEVICE(0x0489, 0xe0b5), /* Foxconn T77W968 ESIM */ |
---|
2110 | | - .driver_info = RSVD(0) | RSVD(1) | RSVD(6) }, |
---|
2111 | | - { USB_DEVICE_INTERFACE_CLASS(0x0489, 0xe0db, 0xff), /* Foxconn T99W265 MBIM */ |
---|
2112 | | - .driver_info = RSVD(3) }, |
---|
2113 | | - { USB_DEVICE(0x1508, 0x1001), /* Fibocom NL668 (IOT version) */ |
---|
| 1991 | + { USB_DEVICE(0x1508, 0x1001), /* Fibocom NL668 */ |
---|
2114 | 1992 | .driver_info = RSVD(4) | RSVD(5) | RSVD(6) }, |
---|
2115 | 1993 | { USB_DEVICE(0x2cb7, 0x0104), /* Fibocom NL678 series */ |
---|
2116 | 1994 | .driver_info = RSVD(4) | RSVD(5) }, |
---|
2117 | 1995 | { USB_DEVICE_INTERFACE_CLASS(0x2cb7, 0x0105, 0xff), /* Fibocom NL678 series */ |
---|
2118 | 1996 | .driver_info = RSVD(6) }, |
---|
2119 | | - { USB_DEVICE_AND_INTERFACE_INFO(0x2cb7, 0x010b, 0xff, 0xff, 0x30) }, /* Fibocom FG150 Diag */ |
---|
2120 | | - { USB_DEVICE_AND_INTERFACE_INFO(0x2cb7, 0x010b, 0xff, 0, 0) }, /* Fibocom FG150 AT */ |
---|
2121 | | - { USB_DEVICE_INTERFACE_CLASS(0x2cb7, 0x01a0, 0xff) }, /* Fibocom NL668-AM/NL652-EU (laptop MBIM) */ |
---|
2122 | | - { USB_DEVICE_INTERFACE_CLASS(0x2cb7, 0x01a2, 0xff) }, /* Fibocom FM101-GL (laptop MBIM) */ |
---|
2123 | | - { USB_DEVICE_INTERFACE_CLASS(0x2cb7, 0x01a4, 0xff), /* Fibocom FM101-GL (laptop MBIM) */ |
---|
2124 | | - .driver_info = RSVD(4) }, |
---|
2125 | | - { USB_DEVICE_INTERFACE_CLASS(0x2df3, 0x9d03, 0xff) }, /* LongSung M5710 */ |
---|
2126 | | - { USB_DEVICE_INTERFACE_CLASS(0x305a, 0x1404, 0xff) }, /* GosunCn GM500 RNDIS */ |
---|
2127 | | - { USB_DEVICE_INTERFACE_CLASS(0x305a, 0x1405, 0xff) }, /* GosunCn GM500 MBIM */ |
---|
2128 | | - { USB_DEVICE_INTERFACE_CLASS(0x305a, 0x1406, 0xff) }, /* GosunCn GM500 ECM/NCM */ |
---|
2129 | 1997 | { } /* Terminating entry */ |
---|
2130 | 1998 | }; |
---|
2131 | 1999 | MODULE_DEVICE_TABLE(usb, option_ids); |
---|
.. | .. |
---|
2134 | 2002 | * recognizes separately, thus num_port=1. |
---|
2135 | 2003 | */ |
---|
2136 | 2004 | |
---|
| 2005 | +#if 1 //Added by Quectel |
---|
| 2006 | +static void cfmakeraw(struct ktermios *t) |
---|
| 2007 | +{ |
---|
| 2008 | + t->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); |
---|
| 2009 | + t->c_oflag &= ~OPOST; |
---|
| 2010 | + t->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN); |
---|
| 2011 | + t->c_cflag &= ~(CSIZE|PARENB); |
---|
| 2012 | + t->c_cflag |= CS8; |
---|
| 2013 | + t->c_cc[VMIN] = 1; |
---|
| 2014 | + t->c_cc[VTIME] = 0; |
---|
| 2015 | +} |
---|
| 2016 | + |
---|
| 2017 | +static void option_init_termios(struct tty_struct *tty) |
---|
| 2018 | +{ |
---|
| 2019 | + cfmakeraw(&tty->termios); |
---|
| 2020 | +} |
---|
| 2021 | +#endif |
---|
| 2022 | + |
---|
2137 | 2023 | static struct usb_serial_driver option_1port_device = { |
---|
| 2024 | + .init_termios = option_init_termios, |
---|
2138 | 2025 | .driver = { |
---|
2139 | 2026 | .owner = THIS_MODULE, |
---|
2140 | 2027 | .name = "option1", |
---|
.. | .. |
---|
2151 | 2038 | .chars_in_buffer = usb_wwan_chars_in_buffer, |
---|
2152 | 2039 | .tiocmget = usb_wwan_tiocmget, |
---|
2153 | 2040 | .tiocmset = usb_wwan_tiocmset, |
---|
2154 | | - .ioctl = usb_wwan_ioctl, |
---|
| 2041 | + .get_serial = usb_wwan_get_serial_info, |
---|
| 2042 | + .set_serial = usb_wwan_set_serial_info, |
---|
2155 | 2043 | .attach = option_attach, |
---|
2156 | 2044 | .release = option_release, |
---|
2157 | 2045 | .port_probe = usb_wwan_port_probe, |
---|
.. | .. |
---|
2160 | 2048 | #ifdef CONFIG_PM |
---|
2161 | 2049 | .suspend = usb_wwan_suspend, |
---|
2162 | 2050 | .resume = usb_wwan_resume, |
---|
| 2051 | +#if 1 //Added by Quectel |
---|
| 2052 | + .reset_resume = usb_wwan_resume, |
---|
| 2053 | +#endif |
---|
2163 | 2054 | #endif |
---|
2164 | 2055 | }; |
---|
2165 | 2056 | |
---|
.. | .. |
---|
2169 | 2060 | |
---|
2170 | 2061 | module_usb_serial_driver(serial_drivers, option_ids); |
---|
2171 | 2062 | |
---|
2172 | | -static bool iface_is_reserved(unsigned long device_flags, u8 ifnum) |
---|
2173 | | -{ |
---|
2174 | | - if (ifnum > FLAG_IFNUM_MAX) |
---|
2175 | | - return false; |
---|
2176 | | - |
---|
2177 | | - return device_flags & RSVD(ifnum); |
---|
2178 | | -} |
---|
2179 | | - |
---|
2180 | 2063 | static int option_probe(struct usb_serial *serial, |
---|
2181 | 2064 | const struct usb_device_id *id) |
---|
2182 | 2065 | { |
---|
2183 | 2066 | struct usb_interface_descriptor *iface_desc = |
---|
2184 | 2067 | &serial->interface->cur_altsetting->desc; |
---|
2185 | 2068 | unsigned long device_flags = id->driver_info; |
---|
| 2069 | + |
---|
| 2070 | +#if 1 //Added by Quectel |
---|
| 2071 | + //Quectel UC20's interface 4 can be used as USB Network device |
---|
| 2072 | + if (serial->dev->descriptor.idVendor == cpu_to_le16(0x05C6) && serial->dev->descriptor.idProduct == cpu_to_le16(0x9003) |
---|
| 2073 | + && serial->interface->cur_altsetting->desc.bInterfaceNumber >= 4) |
---|
| 2074 | + return -ENODEV; |
---|
| 2075 | + |
---|
| 2076 | + //Quectel EC20(MDM9215)'s interface 4 can be used as USB Network device |
---|
| 2077 | + if (serial->dev->descriptor.idVendor == cpu_to_le16(0x05C6) && serial->dev->descriptor.idProduct == cpu_to_le16(0x9215) |
---|
| 2078 | + && serial->interface->cur_altsetting->desc.bInterfaceNumber >= 4) |
---|
| 2079 | + return -ENODEV; |
---|
| 2080 | + |
---|
| 2081 | + if (serial->dev->descriptor.idVendor == cpu_to_le16(0x2C7C)) { |
---|
| 2082 | + __u16 idProduct = le16_to_cpu(serial->dev->descriptor.idProduct); |
---|
| 2083 | + struct usb_interface_descriptor *intf = &serial->interface->cur_altsetting->desc; |
---|
| 2084 | + |
---|
| 2085 | + if (intf->bInterfaceClass != 0xFF || intf->bInterfaceSubClass == 0x42) { |
---|
| 2086 | + //ECM, RNDIS, NCM, MBIM, ACM, UAC, ADB |
---|
| 2087 | + return -ENODEV; |
---|
| 2088 | + } |
---|
| 2089 | + |
---|
| 2090 | + if ((idProduct&0xF000) == 0x0000) { |
---|
| 2091 | + //MDM interface 4 is QMI |
---|
| 2092 | + if (intf->bInterfaceNumber == 4 && intf->bNumEndpoints == 3 |
---|
| 2093 | + && intf->bInterfaceSubClass == 0xFF && intf->bInterfaceProtocol == 0xFF) |
---|
| 2094 | + return -ENODEV; |
---|
| 2095 | + } |
---|
| 2096 | + } |
---|
| 2097 | +#endif |
---|
2186 | 2098 | |
---|
2187 | 2099 | /* Never bind to the CD-Rom emulation interface */ |
---|
2188 | 2100 | if (iface_desc->bInterfaceClass == USB_CLASS_MASS_STORAGE) |
---|
.. | .. |
---|
2193 | 2105 | * the same class/subclass/protocol as the serial interfaces. Look at |
---|
2194 | 2106 | * the Windows driver .INF files for reserved interface numbers. |
---|
2195 | 2107 | */ |
---|
2196 | | - if (iface_is_reserved(device_flags, iface_desc->bInterfaceNumber)) |
---|
| 2108 | + if (device_flags & RSVD(iface_desc->bInterfaceNumber)) |
---|
2197 | 2109 | return -ENODEV; |
---|
2198 | 2110 | |
---|
2199 | 2111 | /* |
---|
.. | .. |
---|
2207 | 2119 | usb_set_serial_data(serial, (void *)device_flags); |
---|
2208 | 2120 | |
---|
2209 | 2121 | return 0; |
---|
2210 | | -} |
---|
2211 | | - |
---|
2212 | | -static bool iface_no_modem_control(unsigned long device_flags, u8 ifnum) |
---|
2213 | | -{ |
---|
2214 | | - if (ifnum > FLAG_IFNUM_MAX) |
---|
2215 | | - return false; |
---|
2216 | | - |
---|
2217 | | - return device_flags & NCTRL(ifnum); |
---|
2218 | 2122 | } |
---|
2219 | 2123 | |
---|
2220 | 2124 | static int option_attach(struct usb_serial *serial) |
---|
.. | .. |
---|
2232 | 2136 | |
---|
2233 | 2137 | iface_desc = &serial->interface->cur_altsetting->desc; |
---|
2234 | 2138 | |
---|
2235 | | - if (!iface_no_modem_control(device_flags, iface_desc->bInterfaceNumber)) |
---|
| 2139 | + if (!(device_flags & NCTRL(iface_desc->bInterfaceNumber))) |
---|
2236 | 2140 | data->use_send_setup = 1; |
---|
2237 | | - |
---|
2238 | | - if (device_flags & ZLP) |
---|
2239 | | - data->use_zlp = 1; |
---|
2240 | 2141 | |
---|
2241 | 2142 | spin_lock_init(&data->susp_lock); |
---|
2242 | 2143 | |
---|
.. | .. |
---|
2298 | 2199 | dev_dbg(dev, "%s: error %d\n", __func__, status); |
---|
2299 | 2200 | |
---|
2300 | 2201 | /* Resubmit urb so we continue receiving IRQ data */ |
---|
2301 | | - if (status != -ESHUTDOWN && status != -ENOENT) { |
---|
| 2202 | + if (status != -ESHUTDOWN && status != -ENOENT && status != -EPROTO) { |
---|
2302 | 2203 | usb_mark_last_busy(port->serial->dev); |
---|
2303 | 2204 | err = usb_submit_urb(urb, GFP_ATOMIC); |
---|
2304 | 2205 | if (err) |
---|