diff options
author | Johannes Berg <johannes.berg@intel.com> | 2012-07-30 13:44:12 -0400 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2012-07-31 10:18:59 -0400 |
commit | c405c6298eacd423098afacf6020ddbda1b0378b (patch) | |
tree | e85dc0a9e88c041a7629c6e77e6e619bbe141704 /net/mac80211/mesh.c | |
parent | 2d56577bc68e56097a1cd6599b678e8cab758e64 (diff) |
mac80211: manage carrier state in mesh
Instead of assuming the carrier is on all
the time in mesh manage it with joining
and leaving the mesh.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/mac80211/mesh.c')
-rw-r--r-- | net/mac80211/mesh.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/net/mac80211/mesh.c b/net/mac80211/mesh.c index 03f1696d7d98..571d5183060e 100644 --- a/net/mac80211/mesh.c +++ b/net/mac80211/mesh.c | |||
@@ -610,6 +610,8 @@ void ieee80211_start_mesh(struct ieee80211_sub_if_data *sdata) | |||
610 | BSS_CHANGED_HT | | 610 | BSS_CHANGED_HT | |
611 | BSS_CHANGED_BASIC_RATES | | 611 | BSS_CHANGED_BASIC_RATES | |
612 | BSS_CHANGED_BEACON_INT); | 612 | BSS_CHANGED_BEACON_INT); |
613 | |||
614 | netif_carrier_on(sdata->dev); | ||
613 | } | 615 | } |
614 | 616 | ||
615 | void ieee80211_stop_mesh(struct ieee80211_sub_if_data *sdata) | 617 | void ieee80211_stop_mesh(struct ieee80211_sub_if_data *sdata) |
@@ -617,6 +619,8 @@ void ieee80211_stop_mesh(struct ieee80211_sub_if_data *sdata) | |||
617 | struct ieee80211_local *local = sdata->local; | 619 | struct ieee80211_local *local = sdata->local; |
618 | struct ieee80211_if_mesh *ifmsh = &sdata->u.mesh; | 620 | struct ieee80211_if_mesh *ifmsh = &sdata->u.mesh; |
619 | 621 | ||
622 | netif_carrier_off(sdata->dev); | ||
623 | |||
620 | ifmsh->mesh_id_len = 0; | 624 | ifmsh->mesh_id_len = 0; |
621 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON_ENABLED); | 625 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON_ENABLED); |
622 | sta_info_flush(local, NULL); | 626 | sta_info_flush(local, NULL); |