|
@@ -269,29 +269,6 @@ err:
|
|
|
return rv;
|
|
|
}
|
|
|
|
|
|
-/* Gobi devices uses identical class/protocol codes for all interfaces regardless
|
|
|
- * of function. Some of these are CDC ACM like and have the exact same endpoints
|
|
|
- * we are looking for. This leaves two possible strategies for identifying the
|
|
|
- * correct interface:
|
|
|
- * a) hardcoding interface number, or
|
|
|
- * b) use the fact that the wwan interface is the only one lacking additional
|
|
|
- * (CDC functional) descriptors
|
|
|
- *
|
|
|
- * Let's see if we can get away with the generic b) solution.
|
|
|
- */
|
|
|
-static int qmi_wwan_bind_gobi(struct usbnet *dev, struct usb_interface *intf)
|
|
|
-{
|
|
|
- int rv = -EINVAL;
|
|
|
-
|
|
|
- /* ignore any interface with additional descriptors */
|
|
|
- if (intf->cur_altsetting->extralen)
|
|
|
- goto err;
|
|
|
-
|
|
|
- rv = qmi_wwan_bind_shared(dev, intf);
|
|
|
-err:
|
|
|
- return rv;
|
|
|
-}
|
|
|
-
|
|
|
static void qmi_wwan_unbind(struct usbnet *dev, struct usb_interface *intf)
|
|
|
{
|
|
|
struct qmi_wwan_state *info = (void *)&dev->data;
|
|
@@ -375,15 +352,15 @@ static const struct driver_info qmi_wwan_shared = {
|
|
|
.manage_power = qmi_wwan_manage_power,
|
|
|
};
|
|
|
|
|
|
-static const struct driver_info qmi_wwan_gobi = {
|
|
|
- .description = "Qualcomm Gobi wwan/QMI device",
|
|
|
+static const struct driver_info qmi_wwan_force_int0 = {
|
|
|
+ .description = "Qualcomm WWAN/QMI device",
|
|
|
.flags = FLAG_WWAN,
|
|
|
- .bind = qmi_wwan_bind_gobi,
|
|
|
+ .bind = qmi_wwan_bind_shared,
|
|
|
.unbind = qmi_wwan_unbind,
|
|
|
.manage_power = qmi_wwan_manage_power,
|
|
|
+ .data = BIT(0), /* interface whitelist bitmap */
|
|
|
};
|
|
|
|
|
|
-/* ZTE suck at making USB descriptors */
|
|
|
static const struct driver_info qmi_wwan_force_int1 = {
|
|
|
.description = "Qualcomm WWAN/QMI device",
|
|
|
.flags = FLAG_WWAN,
|
|
@@ -393,6 +370,15 @@ static const struct driver_info qmi_wwan_force_int1 = {
|
|
|
.data = BIT(1), /* interface whitelist bitmap */
|
|
|
};
|
|
|
|
|
|
+static const struct driver_info qmi_wwan_force_int3 = {
|
|
|
+ .description = "Qualcomm WWAN/QMI device",
|
|
|
+ .flags = FLAG_WWAN,
|
|
|
+ .bind = qmi_wwan_bind_shared,
|
|
|
+ .unbind = qmi_wwan_unbind,
|
|
|
+ .manage_power = qmi_wwan_manage_power,
|
|
|
+ .data = BIT(3), /* interface whitelist bitmap */
|
|
|
+};
|
|
|
+
|
|
|
static const struct driver_info qmi_wwan_force_int4 = {
|
|
|
.description = "Qualcomm WWAN/QMI device",
|
|
|
.flags = FLAG_WWAN,
|
|
@@ -418,16 +404,23 @@ static const struct driver_info qmi_wwan_force_int4 = {
|
|
|
static const struct driver_info qmi_wwan_sierra = {
|
|
|
.description = "Sierra Wireless wwan/QMI device",
|
|
|
.flags = FLAG_WWAN,
|
|
|
- .bind = qmi_wwan_bind_gobi,
|
|
|
+ .bind = qmi_wwan_bind_shared,
|
|
|
.unbind = qmi_wwan_unbind,
|
|
|
.manage_power = qmi_wwan_manage_power,
|
|
|
.data = BIT(8) | BIT(19), /* interface whitelist bitmap */
|
|
|
};
|
|
|
|
|
|
#define HUAWEI_VENDOR_ID 0x12D1
|
|
|
+
|
|
|
+/* Gobi 1000 QMI/wwan interface number is 3 according to qcserial */
|
|
|
+#define QMI_GOBI1K_DEVICE(vend, prod) \
|
|
|
+ USB_DEVICE(vend, prod), \
|
|
|
+ .driver_info = (unsigned long)&qmi_wwan_force_int3
|
|
|
+
|
|
|
+/* Gobi 2000 and Gobi 3000 QMI/wwan interface number is 0 according to qcserial */
|
|
|
#define QMI_GOBI_DEVICE(vend, prod) \
|
|
|
USB_DEVICE(vend, prod), \
|
|
|
- .driver_info = (unsigned long)&qmi_wwan_gobi
|
|
|
+ .driver_info = (unsigned long)&qmi_wwan_force_int0
|
|
|
|
|
|
static const struct usb_device_id products[] = {
|
|
|
{ /* Huawei E392, E398 and possibly others sharing both device id and more... */
|
|
@@ -538,20 +531,24 @@ static const struct usb_device_id products[] = {
|
|
|
.bInterfaceProtocol = 0xff,
|
|
|
.driver_info = (unsigned long)&qmi_wwan_sierra,
|
|
|
},
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9212)}, /* Acer Gobi Modem Device */
|
|
|
- {QMI_GOBI_DEVICE(0x03f0, 0x1f1d)}, /* HP un2400 Gobi Modem Device */
|
|
|
- {QMI_GOBI_DEVICE(0x03f0, 0x371d)}, /* HP un2430 Mobile Broadband Module */
|
|
|
- {QMI_GOBI_DEVICE(0x04da, 0x250d)}, /* Panasonic Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x413c, 0x8172)}, /* Dell Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x1410, 0xa001)}, /* Novatel Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x0b05, 0x1776)}, /* Asus Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x19d2, 0xfff3)}, /* ONDA Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9001)}, /* Generic Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9002)}, /* Generic Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9202)}, /* Generic Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9203)}, /* Generic Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9222)}, /* Generic Gobi Modem device */
|
|
|
- {QMI_GOBI_DEVICE(0x05c6, 0x9009)}, /* Generic Gobi Modem device */
|
|
|
+
|
|
|
+ /* Gobi 1000 devices */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9212)}, /* Acer Gobi Modem Device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x03f0, 0x1f1d)}, /* HP un2400 Gobi Modem Device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x03f0, 0x371d)}, /* HP un2430 Mobile Broadband Module */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x04da, 0x250d)}, /* Panasonic Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x413c, 0x8172)}, /* Dell Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x1410, 0xa001)}, /* Novatel Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x0b05, 0x1776)}, /* Asus Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x19d2, 0xfff3)}, /* ONDA Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9001)}, /* Generic Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9002)}, /* Generic Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9202)}, /* Generic Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9203)}, /* Generic Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9222)}, /* Generic Gobi Modem device */
|
|
|
+ {QMI_GOBI1K_DEVICE(0x05c6, 0x9009)}, /* Generic Gobi Modem device */
|
|
|
+
|
|
|
+ /* Gobi 2000 and 3000 devices */
|
|
|
{QMI_GOBI_DEVICE(0x413c, 0x8186)}, /* Dell Gobi 2000 Modem device (N0218, VU936) */
|
|
|
{QMI_GOBI_DEVICE(0x05c6, 0x920b)}, /* Generic Gobi 2000 Modem device */
|
|
|
{QMI_GOBI_DEVICE(0x05c6, 0x9225)}, /* Sony Gobi 2000 Modem device (N0279, VU730) */
|