Oliver Neukum <oneu...@suse.com> writes: > On Mon, 2016-07-18 at 16:10 +0200, Kristian Evensen wrote: >> On Mon, Jul 18, 2016 at 3:50 PM, Oliver Neukum <oneu...@suse.com> wrote: >> > No, you misunderstand me. I don't want quirks if we can avoid it. >> > But if you need to do this for rndis_host and cdc_ether and maybe other >> > drivers you should not be touching drivers. This belongs into the core >> > ethernet code. Your code is good, but you are putting it in the wrong >> > places. >> >> Ok, sounds good. So far, I have only seen the random MAC issue with >> the three previously mentioned devices, but who knows how many else is >> out there with the same error ... I don't think it should be in the >> core ethernet code, at least not yet, but I agree it would make sense >> to move it to for example usbnet_core(). If you agree, I can prepare a >> patch for it. > > I don't see how it would be specific for a subsystem. If the patch > is correct, it belongs into the networking core.
The bug is in the firmware implementation of the "read unique vendor assigned mac address" functions, and should therefore be fixed there. It cannot be put into the networking core because "read unique vendor assigned mac address" is a hardware dependent function. It's implemented in each ethernet driver based of whatever interface the firmware provides to that register. IMHO, usbnet_get_ethernet_addr() would be the most appropriate place for cdc_ether and other CDC drivers. And generic_rndis_bind() is the correct place for rndis_host. Putting this in usbnet_get_ethernet_addr() will also fix the XMM7160 based devices having an FF:FF:FF:FF:FF:FF mac address (sic). I'm pretty sure there are other examples too. There is no end to the creative crazyness of firmware engineers... An lsusb snippet example: Interface Descriptor: bLength 9 bDescriptorType 4 bInterfaceNumber 0 bAlternateSetting 0 bNumEndpoints 1 bInterfaceClass 2 Communications bInterfaceSubClass 13 bInterfaceProtocol 0 iInterface 5 Sierra Wireless EM7345 4G LTE (NCM) CDC Header: bcdCDC 1.20 CDC Union: bMasterInterface 0 bSlaveInterface 1 CDC NCM: bcdNcmVersion 1.00 bmNetworkCapabilities 0x00 CDC Ethernet: iMacAddress 6 FFFFFFFFFFFF bmEthernetStatistics 0x00000000 wMaxSegmentSize 1514 wNumberMCFilters 0x0000 bNumberPowerFilters 0 FWIW, putting the fix in usbnet_get_ethernet_addr() will not be a problem for qmi_wwan. It will further fix up the resulting random address if required. Bjørn