|
@@ -1150,6 +1150,17 @@ ieee80211_sta_process_chanswitch(struct ieee80211_sub_if_data *sdata,
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ if (cfg80211_chandef_identical(&csa_ie.chandef,
|
|
|
|
+ &sdata->vif.bss_conf.chandef)) {
|
|
|
|
+ if (ifmgd->csa_ignored_same_chan)
|
|
|
|
+ return;
|
|
|
|
+ sdata_info(sdata,
|
|
|
|
+ "AP %pM tries to chanswitch to same channel, ignore\n",
|
|
|
|
+ ifmgd->associated->bssid);
|
|
|
|
+ ifmgd->csa_ignored_same_chan = true;
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
mutex_lock(&local->mtx);
|
|
mutex_lock(&local->mtx);
|
|
mutex_lock(&local->chanctx_mtx);
|
|
mutex_lock(&local->chanctx_mtx);
|
|
conf = rcu_dereference_protected(sdata->vif.chanctx_conf,
|
|
conf = rcu_dereference_protected(sdata->vif.chanctx_conf,
|
|
@@ -1210,6 +1221,7 @@ ieee80211_sta_process_chanswitch(struct ieee80211_sub_if_data *sdata,
|
|
sdata->vif.csa_active = true;
|
|
sdata->vif.csa_active = true;
|
|
sdata->csa_chandef = csa_ie.chandef;
|
|
sdata->csa_chandef = csa_ie.chandef;
|
|
sdata->csa_block_tx = csa_ie.mode;
|
|
sdata->csa_block_tx = csa_ie.mode;
|
|
|
|
+ ifmgd->csa_ignored_same_chan = false;
|
|
|
|
|
|
if (sdata->csa_block_tx)
|
|
if (sdata->csa_block_tx)
|
|
ieee80211_stop_vif_queues(local, sdata,
|
|
ieee80211_stop_vif_queues(local, sdata,
|
|
@@ -2090,6 +2102,7 @@ static void ieee80211_set_disassoc(struct ieee80211_sub_if_data *sdata,
|
|
|
|
|
|
sdata->vif.csa_active = false;
|
|
sdata->vif.csa_active = false;
|
|
ifmgd->csa_waiting_bcn = false;
|
|
ifmgd->csa_waiting_bcn = false;
|
|
|
|
+ ifmgd->csa_ignored_same_chan = false;
|
|
if (sdata->csa_block_tx) {
|
|
if (sdata->csa_block_tx) {
|
|
ieee80211_wake_vif_queues(local, sdata,
|
|
ieee80211_wake_vif_queues(local, sdata,
|
|
IEEE80211_QUEUE_STOP_REASON_CSA);
|
|
IEEE80211_QUEUE_STOP_REASON_CSA);
|