| .. | .. |
|---|
| 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) |
|---|