2016-08-25 11:33 GMT+02:00 Stanislaw Gruszka <sgruszka@xxxxxxxxxx>: > > On Thu, Aug 25, 2016 at 10:19:22AM +0200, Mathias Kresin wrote: > > The EEPROM used on some CPEs has for every device the same generic > > ralink mac in EEPROM and needs to be overridden. > > I don't know what is CPE, but even if I would know that, I most likely > sill will not understand that description. Well, seams to me the commit message can be improved. If a v2 is required or a v2 is required because of the commit message, I'll take care of it. CPE = Customer Premises Equipment or the small plastic box from your ISP at home. The whole point of the patch is that the MAC stored in the wifi EEPROM might not be unique and need to be overridden. I'm aware of three different "home router", where each model has the same generic ralink MAC address stored in the wifi EEPROM. This can cause nasty issues. > > +++ b/drivers/net/wireless/ralink/rt2x00/rt2400pci.c > > @@ -1459,10 +1459,7 @@ static int rt2400pci_validate_eeprom(struct rt2x00_dev *rt2x00dev) > > * Start validation of the data that has been read. > > */ > > mac = rt2x00_eeprom_addr(rt2x00dev, EEPROM_MAC_ADDR_0); > > - if (!is_valid_ether_addr(mac)) { > > - eth_random_addr(mac); > > - rt2x00_eeprom_dbg(rt2x00dev, "MAC: %pM\n", mac); > > - } > > + rt2x00lib_set_mac_address(rt2x00dev, mac); > <snip> > > +#include <linux/of.h> > > +#include <linux/of_net.h> > > > > #include "rt2x00.h" > > #include "rt2x00lib.h" > > @@ -931,6 +933,21 @@ static void rt2x00lib_rate(struct ieee80211_rate *entry, > > entry->flags |= IEEE80211_RATE_SHORT_PREAMBLE; > > } > > > > +void rt2x00lib_set_mac_address(struct rt2x00_dev *rt2x00dev, u8 *eeprom_mac_addr) > > +{ > > + const char *mac_addr; > > + > > + mac_addr = of_get_mac_address(rt2x00dev->dev->of_node); > > Shouldn't use dev_of_node(&rt2x00dev->dev) and check against NULL ? Not sure if dev_of_node() is meant to be used by every driver. Or at least the function is only used by base stuff and not by any driver. The NULL check doesn't seam to me required. The of_node is finally passed to __of_find_property which does the NULL check before using of_node. Mathias