diff options
| author | Ivo van Doorn <ivdoorn@gmail.com> | 2010-07-24 19:32:25 +0200 | 
|---|---|---|
| committer | John W. Linville <linville@tuxdriver.com> | 2010-07-26 15:32:43 -0400 | 
| commit | 06b3cda0c12986f5bba578b918b188d731c4e191 (patch) | |
| tree | e9cad3385d622345f7858cfa5c0f5caed77aeaf2 | |
| parent | d97349797fa76753c747ed8b888414fe78795439 (diff) | |
rt2x00: Fix regression for rt2500pcimaster-2010-07-26
Since commit:
     commit f1aa4c541e98afa8b770a75ccaa8504d0bff44a7
     Author: Ivo van Doorn <ivdoorn@gmail.com>
     Date:   Tue Jun 29 21:38:55 2010 +0200
     rt2x00: Write the BSSID to register when interface is added
mananged mode in rt2500pci was broken, due to intf->bssid containing
random data rather then the expected 00:00:00:00:00:00
This is corrected by sending the BSSID to rt2x00lib_config_intf
only in AP mode where the bssid is set to a valid value.
Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Acked-by: Helmut Schaa <helmut.schaa@googlemail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00mac.c | 19 | 
1 files changed, 13 insertions, 6 deletions
| diff --git a/drivers/net/wireless/rt2x00/rt2x00mac.c b/drivers/net/wireless/rt2x00/rt2x00mac.c index 4d8d2320c9f..235e037e650 100644 --- a/drivers/net/wireless/rt2x00/rt2x00mac.c +++ b/drivers/net/wireless/rt2x00/rt2x00mac.c @@ -273,17 +273,24 @@ int rt2x00mac_add_interface(struct ieee80211_hw *hw,  	mutex_init(&intf->beacon_skb_mutex);  	intf->beacon = entry; -	if (vif->type == NL80211_IFTYPE_AP) -		memcpy(&intf->bssid, vif->addr, ETH_ALEN); -	memcpy(&intf->mac, vif->addr, ETH_ALEN); -  	/*  	 * The MAC adddress must be configured after the device  	 * has been initialized. Otherwise the device can reset  	 * the MAC registers. +	 * The BSSID address must only be configured in AP mode, +	 * however we should not send an empty BSSID address for +	 * STA interfaces at this time, since this can cause +	 * invalid behavior in the device.  	 */ -	rt2x00lib_config_intf(rt2x00dev, intf, vif->type, -			      intf->mac, intf->bssid); +	memcpy(&intf->mac, vif->addr, ETH_ALEN); +	if (vif->type == NL80211_IFTYPE_AP) { +		memcpy(&intf->bssid, vif->addr, ETH_ALEN); +		rt2x00lib_config_intf(rt2x00dev, intf, vif->type, +				      intf->mac, intf->bssid); +	} else { +		rt2x00lib_config_intf(rt2x00dev, intf, vif->type, +				      intf->mac, NULL); +	}  	/*  	 * Some filters depend on the current working mode. We can force | 
