]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
mac80211: fix beacon enable more
authorJohannes Berg <johannes@sipsolutions.net>
Tue, 10 Feb 2009 20:25:42 +0000 (21:25 +0100)
committerJohn W. Linville <linville@tuxdriver.com>
Fri, 13 Feb 2009 18:45:27 +0000 (13:45 -0500)
Hopefully the last required fix ... disable beaconing
only on beaconing interfaces, and thus avoid calling
ieee80211_if_config for purely virtual interfaces
(those driver doesn't know about).

Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
net/mac80211/scan.c

index 50719ea081720f1b70ecf137c709c6f19cfb9534..eddca4e1e13c2810646c02cc02b9ad0022972da6 100644 (file)
@@ -500,7 +500,12 @@ void ieee80211_scan_completed(struct ieee80211_hw *hw)
                } else
                        netif_tx_wake_all_queues(sdata->dev);
 
-               ieee80211_if_config(sdata, IEEE80211_IFCC_BEACON_ENABLED);
+               /* re-enable beaconing */
+               if (sdata->vif.type == NL80211_IFTYPE_AP ||
+                   sdata->vif.type == NL80211_IFTYPE_ADHOC ||
+                   sdata->vif.type == NL80211_IFTYPE_MESH_POINT)
+                       ieee80211_if_config(sdata,
+                                           IEEE80211_IFCC_BEACON_ENABLED);
        }
        mutex_unlock(&local->iflist_mtx);
 
@@ -656,7 +661,12 @@ int ieee80211_start_scan(struct ieee80211_sub_if_data *scan_sdata,
                if (!netif_running(sdata->dev))
                        continue;
 
-               ieee80211_if_config(sdata, IEEE80211_IFCC_BEACON_ENABLED);
+               /* disable beaconing */
+               if (sdata->vif.type == NL80211_IFTYPE_AP ||
+                   sdata->vif.type == NL80211_IFTYPE_ADHOC ||
+                   sdata->vif.type == NL80211_IFTYPE_MESH_POINT)
+                       ieee80211_if_config(sdata,
+                                           IEEE80211_IFCC_BEACON_ENABLED);
 
                if (sdata->vif.type == NL80211_IFTYPE_STATION) {
                        if (sdata->u.sta.flags & IEEE80211_STA_ASSOCIATED) {