mac80211: ignore cqm during csa
authorMichal Kazior <michal.kazior@tieto.com>
Wed, 9 Apr 2014 13:45:36 +0000 (15:45 +0200)
committerJohannes Berg <johannes.berg@intel.com>
Wed, 7 May 2014 09:04:51 +0000 (11:04 +0200)
It is not guaranteed that multi-vif channel
switching is tightly synchronized. It makes sense
to ignore cqm (missing beacons, et al) while csa
is progressing and re-check it after it completes.

Signed-off-by: Michal Kazior <michal.kazior@tieto.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
net/mac80211/mlme.c

index d68e73cbdcd63a60568a17799d3f46a662c1de69..7f073ef1e0a675c3edbb92c049bbc05c02608276 100644 (file)
@@ -988,6 +988,9 @@ static void ieee80211_chswitch_work(struct work_struct *work)
 
        ifmgd->flags &= ~IEEE80211_STA_CSA_RECEIVED;
 
+       ieee80211_sta_reset_beacon_monitor(sdata);
+       ieee80211_sta_reset_conn_monitor(sdata);
+
 out:
        sdata_unlock(sdata);
 }
@@ -3565,6 +3568,9 @@ static void ieee80211_sta_bcn_mon_timer(unsigned long data)
        if (local->quiescing)
                return;
 
+       if (sdata->vif.csa_active)
+               return;
+
        sdata->u.mgd.connection_loss = false;
        ieee80211_queue_work(&sdata->local->hw,
                             &sdata->u.mgd.beacon_connection_loss_work);
@@ -3580,6 +3586,9 @@ static void ieee80211_sta_conn_mon_timer(unsigned long data)
        if (local->quiescing)
                return;
 
+       if (sdata->vif.csa_active)
+               return;
+
        ieee80211_queue_work(&local->hw, &ifmgd->monitor_work);
 }