aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2012-04-03 04:24:00 -0400
committerJohn W. Linville <linville@tuxdriver.com>2012-04-11 16:23:48 -0400
commit3edaf3e61fda3aa9ff8d38445bf92f2bec23bf63 (patch)
tree55cb71f4299d413dd8bd23caeb54304854588b1d /net
parentfe40cb6274988852aa5a84440d8f81c00cea4028 (diff)
mac80211: manage AP netdev carrier state
The AP netdev is really only active when beaconing, so manage the carrier state accordingly. Also do that for VLAN interfaces enslaved to a given AP interface. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net')
-rw-r--r--net/mac80211/cfg.c10
-rw-r--r--net/mac80211/iface.c9
2 files changed, 16 insertions, 3 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c
index 42e1fb2e700f..667d93943399 100644
--- a/net/mac80211/cfg.c
+++ b/net/mac80211/cfg.c
@@ -644,6 +644,10 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
644 644
645 ieee80211_bss_info_change_notify(sdata, changed); 645 ieee80211_bss_info_change_notify(sdata, changed);
646 646
647 netif_carrier_on(dev);
648 list_for_each_entry(vlan, &sdata->u.ap.vlans, u.vlan.list)
649 netif_carrier_on(vlan->dev);
650
647 return 0; 651 return 0;
648} 652}
649 653
@@ -669,7 +673,7 @@ static int ieee80211_change_beacon(struct wiphy *wiphy, struct net_device *dev,
669 673
670static int ieee80211_stop_ap(struct wiphy *wiphy, struct net_device *dev) 674static int ieee80211_stop_ap(struct wiphy *wiphy, struct net_device *dev)
671{ 675{
672 struct ieee80211_sub_if_data *sdata; 676 struct ieee80211_sub_if_data *sdata, *vlan;
673 struct beacon_data *old; 677 struct beacon_data *old;
674 678
675 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 679 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
@@ -678,6 +682,10 @@ static int ieee80211_stop_ap(struct wiphy *wiphy, struct net_device *dev)
678 if (!old) 682 if (!old)
679 return -ENOENT; 683 return -ENOENT;
680 684
685 list_for_each_entry(vlan, &sdata->u.ap.vlans, u.vlan.list)
686 netif_carrier_off(vlan->dev);
687 netif_carrier_off(dev);
688
681 RCU_INIT_POINTER(sdata->u.ap.beacon, NULL); 689 RCU_INIT_POINTER(sdata->u.ap.beacon, NULL);
682 690
683 kfree_rcu(old, rcu_head); 691 kfree_rcu(old, rcu_head);
diff --git a/net/mac80211/iface.c b/net/mac80211/iface.c
index efb433d3dc25..56a38a3088d4 100644
--- a/net/mac80211/iface.c
+++ b/net/mac80211/iface.c
@@ -254,7 +254,11 @@ static int ieee80211_do_open(struct net_device *dev, bool coming_up)
254 254
255 switch (sdata->vif.type) { 255 switch (sdata->vif.type) {
256 case NL80211_IFTYPE_AP_VLAN: 256 case NL80211_IFTYPE_AP_VLAN:
257 /* no need to tell driver */ 257 /* no need to tell driver, but set carrier */
258 if (rtnl_dereference(sdata->bss->beacon))
259 netif_carrier_on(dev);
260 else
261 netif_carrier_off(dev);
258 break; 262 break;
259 case NL80211_IFTYPE_MONITOR: 263 case NL80211_IFTYPE_MONITOR:
260 if (sdata->u.mntr_flags & MONITOR_FLAG_COOK_FRAMES) { 264 if (sdata->u.mntr_flags & MONITOR_FLAG_COOK_FRAMES) {
@@ -294,7 +298,8 @@ static int ieee80211_do_open(struct net_device *dev, bool coming_up)
294 ieee80211_bss_info_change_notify(sdata, changed); 298 ieee80211_bss_info_change_notify(sdata, changed);
295 299
296 if (sdata->vif.type == NL80211_IFTYPE_STATION || 300 if (sdata->vif.type == NL80211_IFTYPE_STATION ||
297 sdata->vif.type == NL80211_IFTYPE_ADHOC) 301 sdata->vif.type == NL80211_IFTYPE_ADHOC ||
302 sdata->vif.type == NL80211_IFTYPE_AP)
298 netif_carrier_off(dev); 303 netif_carrier_off(dev);
299 else 304 else
300 netif_carrier_on(dev); 305 netif_carrier_on(dev);