Search Linux Wireless

Re: [RFC] mac80211: always have a valid master device mac address

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 2007-11-20 at 14:22 +0100, Johannes Berg wrote:
> On Tue, 2007-11-20 at 01:17 +0100, Johannes Berg wrote:
> > Once a while a driver will give us a bogus MAC address. This can be
> > remedied by the user by setting the MAC address on the wlanX interface,
> > but unfortunately one cannot change the address of the wmasterX
> > interface which results in wlanX going up but wmasterX refusing to. This
> > is pretty bad. This patch forces wmasterX to have a valid MAC address.
> > The actual address doesn't matter at all.
> > 
> > Signed-off-by: Johannes Berg <johannes@xxxxxxxxxxxxxxxx>
> > ---
> > Or should we hardcode one and always use that instead of the device
> > address?
> 
> Hmm. Considering this. udev has trouble with devices with the same MAC
> address, maybe we *should* hardcode a different one? That'd also stop
> people from using the master device's MAC address as the "eeprom MAC"
> that should be gotten from sysfs instead. It's bound to happen ;)

It's a udev _rules_ problem, not a udev problem really.  Because
mac80211 was quite new, the udev rules weren't differentiating between
the wmaster and the wlan interfaces.  The rules need to be updated (and
have been for many distros) to check the 'type' attribute of the sysfs
dir of the device before deciding what to do with it.

Dan

> > --- everything.orig/net/mac80211/ieee80211.c	2007-11-20 00:25:03.008708602 +0100
> > +++ everything/net/mac80211/ieee80211.c	2007-11-20 00:27:09.278700356 +0100
> > @@ -1286,6 +1286,8 @@ int ieee80211_register_hw(struct ieee802
> >  		goto fail_dev;
> >  
> >  	memcpy(local->mdev->dev_addr, local->hw.wiphy->perm_addr, ETH_ALEN);
> > +	if (!is_valid_ether_addr(local->mdev->dev_addr))
> > +		random_ether_addr(local->mdev->dev_addr);
> >  	SET_NETDEV_DEV(local->mdev, wiphy_dev(local->hw.wiphy));
> >  
> >  	result = register_netdevice(local->mdev);
> > 
> > 
> > -
> > To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
> > the body of a message to majordomo@xxxxxxxxxxxxxxx
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> > 

-
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux