Lines Matching +full:1 +full:- +full:based
1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * CDC Ethernet based networking peripherals
4 * Copyright (C) 2003-2005 by David Brownell
26 return (desc->bInterfaceClass == USB_CLASS_COMM && in is_rndis()
27 desc->bInterfaceSubClass == 2 && in is_rndis()
28 desc->bInterfaceProtocol == 0xff); in is_rndis()
33 return (desc->bInterfaceClass == USB_CLASS_MISC && in is_activesync()
34 desc->bInterfaceSubClass == 1 && in is_activesync()
35 desc->bInterfaceProtocol == 1); in is_activesync()
40 return (desc->bInterfaceClass == USB_CLASS_WIRELESS_CONTROLLER && in is_wireless_rndis()
41 desc->bInterfaceSubClass == 1 && in is_wireless_rndis()
42 desc->bInterfaceProtocol == 3); in is_wireless_rndis()
47 return (desc->bInterfaceClass == USB_CLASS_MISC && in is_novatel_rndis()
48 desc->bInterfaceSubClass == 4 && in is_novatel_rndis()
49 desc->bInterfaceProtocol == 1); in is_novatel_rndis()
68 struct net_device *net = dev->net; in usbnet_cdc_update_filter()
77 if (net->flags & IFF_PROMISC) in usbnet_cdc_update_filter()
79 if (!netdev_mc_empty(net) || (net->flags & IFF_ALLMULTI)) in usbnet_cdc_update_filter()
82 usb_control_msg(dev->udev, in usbnet_cdc_update_filter()
83 usb_sndctrlpipe(dev->udev, 0), in usbnet_cdc_update_filter()
87 dev->intf->cur_altsetting->desc.bInterfaceNumber, in usbnet_cdc_update_filter()
102 u8 *buf = intf->cur_altsetting->extra; in usbnet_generic_cdc_bind()
103 int len = intf->cur_altsetting->extralen; in usbnet_generic_cdc_bind()
105 struct cdc_state *info = (void *) &dev->data; in usbnet_generic_cdc_bind()
112 if (sizeof(dev->data) < sizeof(*info)) in usbnet_generic_cdc_bind()
113 return -EDOM; in usbnet_generic_cdc_bind()
118 if (len == 0 && dev->udev->actconfig->extralen) { in usbnet_generic_cdc_bind()
122 buf = dev->udev->actconfig->extra; in usbnet_generic_cdc_bind()
123 len = dev->udev->actconfig->extralen; in usbnet_generic_cdc_bind()
124 dev_dbg(&intf->dev, "CDC descriptors on config\n"); in usbnet_generic_cdc_bind()
128 * been seen on some 2Wire Inc RNDIS-ish products. in usbnet_generic_cdc_bind()
133 hep = intf->cur_altsetting->endpoint; in usbnet_generic_cdc_bind()
135 buf = hep->extra; in usbnet_generic_cdc_bind()
136 len = hep->extralen; in usbnet_generic_cdc_bind()
139 dev_dbg(&intf->dev, in usbnet_generic_cdc_bind()
143 /* this assumes that if there's a non-RNDIS vendor variant in usbnet_generic_cdc_bind()
144 * of cdc-acm, it'll fail RNDIS requests cleanly. in usbnet_generic_cdc_bind()
146 rndis = (is_rndis(&intf->cur_altsetting->desc) || in usbnet_generic_cdc_bind()
147 is_activesync(&intf->cur_altsetting->desc) || in usbnet_generic_cdc_bind()
148 is_wireless_rndis(&intf->cur_altsetting->desc) || in usbnet_generic_cdc_bind()
149 is_novatel_rndis(&intf->cur_altsetting->desc)); in usbnet_generic_cdc_bind()
152 info->control = intf; in usbnet_generic_cdc_bind()
156 info->u = header.usb_cdc_union_desc; in usbnet_generic_cdc_bind()
157 info->header = header.usb_cdc_header_desc; in usbnet_generic_cdc_bind()
158 info->ether = header.usb_cdc_ether_desc; in usbnet_generic_cdc_bind()
159 if (!info->u) { in usbnet_generic_cdc_bind()
169 info->control = usb_ifnum_to_if(dev->udev, info->u->bMasterInterface0); in usbnet_generic_cdc_bind()
170 info->data = usb_ifnum_to_if(dev->udev, info->u->bSlaveInterface0); in usbnet_generic_cdc_bind()
171 if (!info->control || !info->data) { in usbnet_generic_cdc_bind()
172 dev_dbg(&intf->dev, in usbnet_generic_cdc_bind()
174 info->u->bMasterInterface0, in usbnet_generic_cdc_bind()
175 info->control, in usbnet_generic_cdc_bind()
176 info->u->bSlaveInterface0, in usbnet_generic_cdc_bind()
177 info->data); in usbnet_generic_cdc_bind()
178 /* fall back to hard-wiring for RNDIS */ in usbnet_generic_cdc_bind()
185 if (info->control != intf) { in usbnet_generic_cdc_bind()
186 dev_dbg(&intf->dev, "bogus CDC Union\n"); in usbnet_generic_cdc_bind()
190 if (info->data == intf) { in usbnet_generic_cdc_bind()
191 info->data = info->control; in usbnet_generic_cdc_bind()
192 info->control = intf; in usbnet_generic_cdc_bind()
197 /* some devices merge these - skip class check */ in usbnet_generic_cdc_bind()
198 if (info->control == info->data) in usbnet_generic_cdc_bind()
202 d = &info->data->cur_altsetting->desc; in usbnet_generic_cdc_bind()
203 if (d->bInterfaceClass != USB_CLASS_CDC_DATA) { in usbnet_generic_cdc_bind()
204 dev_dbg(&intf->dev, "slave class %u\n", d->bInterfaceClass); in usbnet_generic_cdc_bind()
215 if (rndis && is_rndis(&intf->cur_altsetting->desc) && in usbnet_generic_cdc_bind()
217 header.usb_cdc_acm_descriptor->bmCapabilities) { in usbnet_generic_cdc_bind()
218 dev_dbg(&intf->dev, in usbnet_generic_cdc_bind()
220 header.usb_cdc_acm_descriptor->bmCapabilities); in usbnet_generic_cdc_bind()
224 if (header.usb_cdc_ether_desc && info->ether->wMaxSegmentSize) { in usbnet_generic_cdc_bind()
225 dev->hard_mtu = le16_to_cpu(info->ether->wMaxSegmentSize); in usbnet_generic_cdc_bind()
232 memcmp(header.usb_cdc_mdlm_desc->bGUID, mbm_guid, 16)) { in usbnet_generic_cdc_bind()
233 dev_dbg(&intf->dev, "GUID doesn't match\n"); in usbnet_generic_cdc_bind()
238 header.usb_cdc_mdlm_detail_desc->bLength < in usbnet_generic_cdc_bind()
239 (sizeof(struct usb_cdc_mdlm_detail_desc) + 1)) { in usbnet_generic_cdc_bind()
240 dev_dbg(&intf->dev, "Descriptor too short\n"); in usbnet_generic_cdc_bind()
246 /* Microsoft ActiveSync based and some regular RNDIS devices lack the in usbnet_generic_cdc_bind()
247 * CDC descriptors, so we'll hard-wire the interfaces and not check in usbnet_generic_cdc_bind()
251 * to non-existing interfaces. Ignore that and attempt the same in usbnet_generic_cdc_bind()
252 * hard-wired 0 and 1 interfaces. in usbnet_generic_cdc_bind()
254 if (rndis && (!info->u || android_rndis_quirk)) { in usbnet_generic_cdc_bind()
255 info->control = usb_ifnum_to_if(dev->udev, 0); in usbnet_generic_cdc_bind()
256 info->data = usb_ifnum_to_if(dev->udev, 1); in usbnet_generic_cdc_bind()
257 if (!info->control || !info->data || info->control != intf) { in usbnet_generic_cdc_bind()
258 dev_dbg(&intf->dev, in usbnet_generic_cdc_bind()
259 "rndis: master #0/%p slave #1/%p\n", in usbnet_generic_cdc_bind()
260 info->control, in usbnet_generic_cdc_bind()
261 info->data); in usbnet_generic_cdc_bind()
265 } else if (!info->header || (!rndis && !info->ether)) { in usbnet_generic_cdc_bind()
266 dev_dbg(&intf->dev, "missing cdc %s%s%sdescriptor\n", in usbnet_generic_cdc_bind()
267 info->header ? "" : "header ", in usbnet_generic_cdc_bind()
268 info->u ? "" : "union ", in usbnet_generic_cdc_bind()
269 info->ether ? "" : "ether "); in usbnet_generic_cdc_bind()
276 if (info->data != info->control) { in usbnet_generic_cdc_bind()
277 status = usb_driver_claim_interface(driver, info->data, dev); in usbnet_generic_cdc_bind()
281 status = usbnet_get_endpoints(dev, info->data); in usbnet_generic_cdc_bind()
284 usb_set_intfdata(info->data, NULL); in usbnet_generic_cdc_bind()
285 if (info->data != info->control) in usbnet_generic_cdc_bind()
286 usb_driver_release_interface(driver, info->data); in usbnet_generic_cdc_bind()
291 if (info->data != info->control) in usbnet_generic_cdc_bind()
292 dev->status = NULL; in usbnet_generic_cdc_bind()
293 if (info->control->cur_altsetting->desc.bNumEndpoints == 1) { in usbnet_generic_cdc_bind()
296 dev->status = &info->control->cur_altsetting->endpoint[0]; in usbnet_generic_cdc_bind()
297 desc = &dev->status->desc; in usbnet_generic_cdc_bind()
299 (le16_to_cpu(desc->wMaxPacketSize) in usbnet_generic_cdc_bind()
301 !desc->bInterval) { in usbnet_generic_cdc_bind()
302 dev_dbg(&intf->dev, "bad notification endpoint\n"); in usbnet_generic_cdc_bind()
303 dev->status = NULL; in usbnet_generic_cdc_bind()
306 if (rndis && !dev->status) { in usbnet_generic_cdc_bind()
307 dev_dbg(&intf->dev, "missing RNDIS status endpoint\n"); in usbnet_generic_cdc_bind()
308 usb_set_intfdata(info->data, NULL); in usbnet_generic_cdc_bind()
309 usb_driver_release_interface(driver, info->data); in usbnet_generic_cdc_bind()
310 return -ENODEV; in usbnet_generic_cdc_bind()
316 dev_info(&dev->udev->dev, "bad CDC descriptors\n"); in usbnet_generic_cdc_bind()
317 return -ENODEV; in usbnet_generic_cdc_bind()
347 struct cdc_state *info = (void *) &dev->data; in usbnet_cdc_unbind()
350 /* combined interface - nothing to do */ in usbnet_cdc_unbind()
351 if (info->data == info->control) in usbnet_cdc_unbind()
354 /* disconnect master --> disconnect slave */ in usbnet_cdc_unbind()
355 if (intf == info->control && info->data) { in usbnet_cdc_unbind()
357 usb_set_intfdata(info->data, NULL); in usbnet_cdc_unbind()
358 usb_driver_release_interface(driver, info->data); in usbnet_cdc_unbind()
359 info->data = NULL; in usbnet_cdc_unbind()
363 else if (intf == info->data && info->control) { in usbnet_cdc_unbind()
365 usb_set_intfdata(info->control, NULL); in usbnet_cdc_unbind()
366 usb_driver_release_interface(driver, info->control); in usbnet_cdc_unbind()
367 info->control = NULL; in usbnet_cdc_unbind()
384 netif_info(dev, timer, dev->net, in dumpspeed()
387 __le32_to_cpu(speeds[1]) / 1000); in dumpspeed()
394 if (urb->actual_length < sizeof(*event)) in usbnet_cdc_status()
397 /* SPEED_CHANGE can get split into two 8-byte packets */ in usbnet_cdc_status()
398 if (test_and_clear_bit(EVENT_STS_SPLIT, &dev->flags)) { in usbnet_cdc_status()
399 dumpspeed(dev, (__le32 *) urb->transfer_buffer); in usbnet_cdc_status()
403 event = urb->transfer_buffer; in usbnet_cdc_status()
404 switch (event->bNotificationType) { in usbnet_cdc_status()
406 netif_dbg(dev, timer, dev->net, "CDC: carrier %s\n", in usbnet_cdc_status()
407 event->wValue ? "on" : "off"); in usbnet_cdc_status()
408 usbnet_link_change(dev, !!event->wValue, 0); in usbnet_cdc_status()
411 netif_dbg(dev, timer, dev->net, "CDC: speed change (len %d)\n", in usbnet_cdc_status()
412 urb->actual_length); in usbnet_cdc_status()
413 if (urb->actual_length != (sizeof(*event) + 8)) in usbnet_cdc_status()
414 set_bit(EVENT_STS_SPLIT, &dev->flags); in usbnet_cdc_status()
416 dumpspeed(dev, (__le32 *) &event[1]); in usbnet_cdc_status()
422 netdev_err(dev->net, "CDC: unexpected notification %02x!\n", in usbnet_cdc_status()
423 event->bNotificationType); in usbnet_cdc_status()
432 struct cdc_state *info = (void *) &dev->data; in usbnet_cdc_bind()
434 BUILD_BUG_ON((sizeof(((struct usbnet *)0)->data) in usbnet_cdc_bind()
441 status = usbnet_get_ethernet_addr(dev, info->ether->iMACAddress); in usbnet_cdc_bind()
443 usb_set_intfdata(info->data, NULL); in usbnet_cdc_bind()
444 usb_driver_release_interface(driver_of(intf), info->data); in usbnet_cdc_bind()
456 if (!status && (dev->net->dev_addr[0] & 0x02)) in usbnet_cdc_zte_bind()
457 eth_hw_addr_random(dev->net); in usbnet_cdc_zte_bind()
471 if (skb->len < ETH_HLEN || !(skb->data[0] & 0x02)) in usbnet_cdc_zte_rx_fixup()
472 return 1; in usbnet_cdc_zte_rx_fixup()
475 ether_addr_copy(eth_hdr(skb)->h_dest, dev->net->dev_addr); in usbnet_cdc_zte_rx_fixup()
477 return 1; in usbnet_cdc_zte_rx_fixup()
490 if (urb->actual_length < sizeof(*event)) in usbnet_cdc_zte_status()
493 event = urb->transfer_buffer; in usbnet_cdc_zte_status()
495 if (event->bNotificationType != USB_CDC_NOTIFY_NETWORK_CONNECTION) { in usbnet_cdc_zte_status()
500 netif_dbg(dev, timer, dev->net, "CDC: carrier %s\n", in usbnet_cdc_zte_status()
501 event->wValue ? "on" : "off"); in usbnet_cdc_zte_status()
503 if (event->wValue && in usbnet_cdc_zte_status()
504 netif_carrier_ok(dev->net)) in usbnet_cdc_zte_status()
505 netif_carrier_off(dev->net); in usbnet_cdc_zte_status()
507 usbnet_link_change(dev, !!event->wValue, 0); in usbnet_cdc_zte_status()
541 /*-------------------------------------------------------------------------*/
573 /* SA-1100 based Sharp Zaurus ("collie"), or compatible;
574 * wire-incompatible with true CDC Ethernet implementations.
586 /* PXA-25x based Sharp Zaurii. Note that it seems some of these
595 .idProduct = 0x8005, /* A-300 */
602 .idProduct = 0x8006, /* B-500/SL-5600 */
609 .idProduct = 0x8007, /* C-700 */
616 .idProduct = 0x9031, /* C-750 C-760 */
623 .idProduct = 0x9032, /* SL-6000 */
631 .idProduct = 0x9050, /* C-860 */
636 /* Olympus has some models with a Zaurus-compatible option.
637 * R-1000 uses a FreeScale i.MXL cpu (ARMv4T)
643 .idProduct = 0x0F02, /* R-1000 */
655 /* Logitech Harmony 900 - uses the pseudo-MDLM (BLAN) driver */
662 /* Novatel USB551L and MC551 - handled by qmi_wwan */
669 /* Novatel E362 - handled by qmi_wwan */
676 /* Dell Wireless 5800 (Novatel E362) - handled by qmi_wwan */
683 /* Dell Wireless 5800 (Novatel E362) - handled by qmi_wwan */
690 /* Dell Wireless 5804 (Novatel E371) - handled by qmi_wwan */
697 /* Novatel Expedite E371 - handled by qmi_wwan */
704 /* HP lt2523 (Novatel E371) - handled by qmi_wwan */
711 /* AnyDATA ADU960S - handled by qmi_wwan */
718 /* Huawei E1820 - handled by qmi_wwan */
720 USB_DEVICE_INTERFACE_NUMBER(HUAWEI_VENDOR_ID, 0x14ac, 1),
724 /* Realtek RTL8152 Based USB 2.0 Ethernet Adapters */
731 /* Realtek RTL8153 Based USB 3.0 Ethernet Adapters */
754 /* ThinkPad USB-C Dock (based on Realtek RTL8153) */
761 /* ThinkPad Thunderbolt 3 Dock (based on Realtek RTL8153) */
768 /* ThinkPad Thunderbolt 3 Dock Gen 2 (based on Realtek RTL8153) */
775 /* Lenovo Thinkpad USB 3.0 Ethernet Adapters (based on Realtek RTL8153) */
782 /* Lenovo USB C to Ethernet Adapter (based on Realtek RTL8153) */
789 /* Lenovo USB-C Travel Hub (based on Realtek RTL8153) */
796 /* ThinkPad USB-C Dock Gen 2 (based on Realtek RTL8153) */
803 /* NVIDIA Tegra USB 3.0 Ethernet Adapters (based on Realtek RTL8153) */
810 /* Microsoft Surface 2 dock (based on Realtek RTL8152) */
817 /* Microsoft Surface Ethernet Adapter (based on Realtek RTL8153) */
824 /* Microsoft Surface Ethernet Adapter (based on Realtek RTL8153B) */
831 /* TP-LINK UE300 USB 3.0 Ethernet Adapters (based on Realtek RTL8153) */
838 /* Aquantia AQtion USB to 5GbE Controller (based on AQC111U) */
846 /* ASIX USB 3.1 Gen1 to 5G Multi-Gigabit Ethernet Adapter(based on AQC111U) */
854 /* ASIX USB 3.1 Gen1 to 2.5G Multi-Gigabit Ethernet Adapter(based on AQC112U) */
862 /* USB-C 3.1 to 5GBASE-T Ethernet Adapter (based on AQC111U) */
870 /* QNAP QNA-UC5G1T USB to 5GbE Adapter (based on AQC111U) */
889 /* ZTE (Vodafone) K3805-Z */
895 /* ZTE (Vodafone) K3806-Z */
901 /* ZTE (Vodafone) K4510-Z */
907 /* ZTE (Vodafone) K3770-Z */
913 /* ZTE (Vodafone) K3772-Z */
941 /* U-blox TOBY-L2 */
947 /* U-blox SARA-U2 */
991 .supports_autosuspend = 1,
992 .disable_hub_initiated_lpm = 1,