Message ID | 1384430976-13708-1-git-send-email-luciano.coelho@intel.com (mailing list archive) |
---|---|
State | Not Applicable, archived |
Headers | show |
Hi, Just to clarify, these patches are now based on mac80211-next (thanks Simon), so we don't need to apply anything manually (as with the previous patch set that was based on wireless-testing). Please review and test, especially the MESH and IBSS parts! -- Cheers, Luca. On Thu, 2013-11-14 at 14:09 +0200, Luciano Coelho wrote: > Refactor ieee80211_ibss_process_chanswitch() to use > ieee80211_channel_switch() and avoid code duplication. > > Change-Id: I265a12c7f825dc20535bad1197a81437310d0086 > Signed-off-by: Luciano Coelho <luciano.coelho@intel.com> > --- > net/mac80211/cfg.c | 4 ++-- > net/mac80211/ibss.c | 58 +++++++--------------------------------------- > net/mac80211/ieee80211_i.h | 2 ++ > 3 files changed, 12 insertions(+), 52 deletions(-) > > diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c > index 3bc92d0..a98dc6b 100644 > --- a/net/mac80211/cfg.c > +++ b/net/mac80211/cfg.c > @@ -3035,8 +3035,8 @@ void ieee80211_csa_finalize_work(struct work_struct *work) > cfg80211_ch_switch_notify(sdata->dev, &sdata->csa_chandef); > } > > -static int ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, > - struct cfg80211_csa_settings *params) > +int ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, > + struct cfg80211_csa_settings *params) > { > struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev); > struct ieee80211_local *local = sdata->local; > diff --git a/net/mac80211/ibss.c b/net/mac80211/ibss.c > index 0f1fb5d..3514aab 100644 > --- a/net/mac80211/ibss.c > +++ b/net/mac80211/ibss.c > @@ -784,18 +784,10 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, > struct cfg80211_csa_settings params; > struct ieee80211_csa_ie csa_ie; > struct ieee80211_if_ibss *ifibss = &sdata->u.ibss; > - struct ieee80211_chanctx_conf *chanctx_conf; > - struct ieee80211_chanctx *chanctx; > enum nl80211_channel_type ch_type; > - int err, num_chanctx; > + int err; > u32 sta_flags; > > - if (sdata->vif.csa_active) > - return true; > - > - if (!sdata->vif.bss_conf.ibss_joined) > - return false; > - > sta_flags = IEEE80211_STA_DISABLE_VHT; > switch (ifibss->chandef.width) { > case NL80211_CHAN_WIDTH_5: > @@ -826,9 +818,6 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, > params.count = csa_ie.count; > params.chandef = csa_ie.chandef; > > - if (ifibss->chandef.chan->band != params.chandef.chan->band) > - goto disconnect; > - > switch (ifibss->chandef.width) { > case NL80211_CHAN_WIDTH_20_NOHT: > case NL80211_CHAN_WIDTH_20: > @@ -884,29 +873,6 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, > params.radar_required = true; > } > > - rcu_read_lock(); > - chanctx_conf = rcu_dereference(sdata->vif.chanctx_conf); > - if (!chanctx_conf) { > - rcu_read_unlock(); > - goto disconnect; > - } > - > - /* don't handle for multi-VIF cases */ > - chanctx = container_of(chanctx_conf, struct ieee80211_chanctx, conf); > - if (chanctx->refcount > 1) { > - rcu_read_unlock(); > - goto disconnect; > - } > - num_chanctx = 0; > - list_for_each_entry_rcu(chanctx, &sdata->local->chanctx_list, list) > - num_chanctx++; > - > - if (num_chanctx > 1) { > - rcu_read_unlock(); > - goto disconnect; > - } > - rcu_read_unlock(); > - > /* all checks done, now perform the channel switch. */ > ibss_dbg(sdata, > "received channel switch announcement to go to channel %d MHz\n", > @@ -914,19 +880,9 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, > > params.block_tx = !!csa_ie.mode; > > - ieee80211_ibss_csa_beacon(sdata, ¶ms); > - sdata->csa_radar_required = params.radar_required; > - > - if (params.block_tx) > - ieee80211_stop_queues_by_reason(&sdata->local->hw, > - IEEE80211_MAX_QUEUE_MAP, > - IEEE80211_QUEUE_STOP_REASON_CSA); > - > - sdata->csa_chandef = params.chandef; > - sdata->vif.csa_active = true; > - > - ieee80211_bss_info_change_notify(sdata, err); > - drv_channel_switch_beacon(sdata, ¶ms.chandef); > + if (ieee80211_channel_switch(sdata->local->hw.wiphy, sdata->dev, > + ¶ms)) > + goto disconnect; > > ieee80211_ibss_csa_mark_radar(sdata); > > @@ -962,7 +918,8 @@ ieee80211_rx_mgmt_spectrum_mgmt(struct ieee80211_sub_if_data *sdata, > if (len < required_len) > return; > > - ieee80211_ibss_process_chanswitch(sdata, elems, false); > + if (!sdata->vif.csa_active) > + ieee80211_ibss_process_chanswitch(sdata, elems, false); > } > > static void ieee80211_rx_mgmt_deauth_ibss(struct ieee80211_sub_if_data *sdata, > @@ -1143,7 +1100,8 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata, > goto put_bss; > > /* process channel switch */ > - if (ieee80211_ibss_process_chanswitch(sdata, elems, true)) > + if (sdata->vif.csa_active || > + ieee80211_ibss_process_chanswitch(sdata, elems, true)) > goto put_bss; > > /* same BSSID */ > diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h > index 0edc1fb..3a77ed1 100644 > --- a/net/mac80211/ieee80211_i.h > +++ b/net/mac80211/ieee80211_i.h > @@ -1412,6 +1412,8 @@ void ieee80211_handle_roc_started(struct ieee80211_roc_work *roc); > > /* channel switch handling */ > void ieee80211_csa_finalize_work(struct work_struct *work); > +int ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, > + struct cfg80211_csa_settings *params); > > /* interface handling */ > int ieee80211_iface_init(void); -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index 3bc92d0..a98dc6b 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c @@ -3035,8 +3035,8 @@ void ieee80211_csa_finalize_work(struct work_struct *work) cfg80211_ch_switch_notify(sdata->dev, &sdata->csa_chandef); } -static int ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, - struct cfg80211_csa_settings *params) +int ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, + struct cfg80211_csa_settings *params) { struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev); struct ieee80211_local *local = sdata->local; diff --git a/net/mac80211/ibss.c b/net/mac80211/ibss.c index 0f1fb5d..3514aab 100644 --- a/net/mac80211/ibss.c +++ b/net/mac80211/ibss.c @@ -784,18 +784,10 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, struct cfg80211_csa_settings params; struct ieee80211_csa_ie csa_ie; struct ieee80211_if_ibss *ifibss = &sdata->u.ibss; - struct ieee80211_chanctx_conf *chanctx_conf; - struct ieee80211_chanctx *chanctx; enum nl80211_channel_type ch_type; - int err, num_chanctx; + int err; u32 sta_flags; - if (sdata->vif.csa_active) - return true; - - if (!sdata->vif.bss_conf.ibss_joined) - return false; - sta_flags = IEEE80211_STA_DISABLE_VHT; switch (ifibss->chandef.width) { case NL80211_CHAN_WIDTH_5: @@ -826,9 +818,6 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, params.count = csa_ie.count; params.chandef = csa_ie.chandef; - if (ifibss->chandef.chan->band != params.chandef.chan->band) - goto disconnect; - switch (ifibss->chandef.width) { case NL80211_CHAN_WIDTH_20_NOHT: case NL80211_CHAN_WIDTH_20: @@ -884,29 +873,6 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, params.radar_required = true; } - rcu_read_lock(); - chanctx_conf = rcu_dereference(sdata->vif.chanctx_conf); - if (!chanctx_conf) { - rcu_read_unlock(); - goto disconnect; - } - - /* don't handle for multi-VIF cases */ - chanctx = container_of(chanctx_conf, struct ieee80211_chanctx, conf); - if (chanctx->refcount > 1) { - rcu_read_unlock(); - goto disconnect; - } - num_chanctx = 0; - list_for_each_entry_rcu(chanctx, &sdata->local->chanctx_list, list) - num_chanctx++; - - if (num_chanctx > 1) { - rcu_read_unlock(); - goto disconnect; - } - rcu_read_unlock(); - /* all checks done, now perform the channel switch. */ ibss_dbg(sdata, "received channel switch announcement to go to channel %d MHz\n", @@ -914,19 +880,9 @@ ieee80211_ibss_process_chanswitch(struct ieee80211_sub_if_data *sdata, params.block_tx = !!csa_ie.mode; - ieee80211_ibss_csa_beacon(sdata, ¶ms); - sdata->csa_radar_required = params.radar_required; - - if (params.block_tx) - ieee80211_stop_queues_by_reason(&sdata->local->hw, - IEEE80211_MAX_QUEUE_MAP, - IEEE80211_QUEUE_STOP_REASON_CSA); - - sdata->csa_chandef = params.chandef; - sdata->vif.csa_active = true; - - ieee80211_bss_info_change_notify(sdata, err); - drv_channel_switch_beacon(sdata, ¶ms.chandef); + if (ieee80211_channel_switch(sdata->local->hw.wiphy, sdata->dev, + ¶ms)) + goto disconnect; ieee80211_ibss_csa_mark_radar(sdata); @@ -962,7 +918,8 @@ ieee80211_rx_mgmt_spectrum_mgmt(struct ieee80211_sub_if_data *sdata, if (len < required_len) return; - ieee80211_ibss_process_chanswitch(sdata, elems, false); + if (!sdata->vif.csa_active) + ieee80211_ibss_process_chanswitch(sdata, elems, false); } static void ieee80211_rx_mgmt_deauth_ibss(struct ieee80211_sub_if_data *sdata, @@ -1143,7 +1100,8 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata, goto put_bss; /* process channel switch */ - if (ieee80211_ibss_process_chanswitch(sdata, elems, true)) + if (sdata->vif.csa_active || + ieee80211_ibss_process_chanswitch(sdata, elems, true)) goto put_bss; /* same BSSID */ diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h index 0edc1fb..3a77ed1 100644 --- a/net/mac80211/ieee80211_i.h +++ b/net/mac80211/ieee80211_i.h @@ -1412,6 +1412,8 @@ void ieee80211_handle_roc_started(struct ieee80211_roc_work *roc); /* channel switch handling */ void ieee80211_csa_finalize_work(struct work_struct *work); +int ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, + struct cfg80211_csa_settings *params); /* interface handling */ int ieee80211_iface_init(void);
Refactor ieee80211_ibss_process_chanswitch() to use ieee80211_channel_switch() and avoid code duplication. Change-Id: I265a12c7f825dc20535bad1197a81437310d0086 Signed-off-by: Luciano Coelho <luciano.coelho@intel.com> --- net/mac80211/cfg.c | 4 ++-- net/mac80211/ibss.c | 58 +++++++--------------------------------------- net/mac80211/ieee80211_i.h | 2 ++ 3 files changed, 12 insertions(+), 52 deletions(-)