|
@@ -840,6 +840,14 @@ static void ieee80211_direct_probe(struct ieee80211_sub_if_data *sdata,
|
|
|
sdata->dev->name, ifsta->bssid);
|
|
|
ifsta->state = IEEE80211_STA_MLME_DISABLED;
|
|
|
ieee80211_sta_send_apinfo(sdata, ifsta);
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Most likely AP is not in the range so remove the
|
|
|
+ * bss information associated to the AP
|
|
|
+ */
|
|
|
+ ieee80211_rx_bss_remove(sdata, ifsta->bssid,
|
|
|
+ sdata->local->hw.conf.channel->center_freq,
|
|
|
+ ifsta->ssid, ifsta->ssid_len);
|
|
|
return;
|
|
|
}
|
|
|
|
|
@@ -871,6 +879,9 @@ static void ieee80211_authenticate(struct ieee80211_sub_if_data *sdata,
|
|
|
sdata->dev->name, ifsta->bssid);
|
|
|
ifsta->state = IEEE80211_STA_MLME_DISABLED;
|
|
|
ieee80211_sta_send_apinfo(sdata, ifsta);
|
|
|
+ ieee80211_rx_bss_remove(sdata, ifsta->bssid,
|
|
|
+ sdata->local->hw.conf.channel->center_freq,
|
|
|
+ ifsta->ssid, ifsta->ssid_len);
|
|
|
return;
|
|
|
}
|
|
|
|
|
@@ -933,8 +944,12 @@ static void ieee80211_set_disassoc(struct ieee80211_sub_if_data *sdata,
|
|
|
|
|
|
ieee80211_sta_send_apinfo(sdata, ifsta);
|
|
|
|
|
|
- if (self_disconnected || reason == WLAN_REASON_DISASSOC_STA_HAS_LEFT)
|
|
|
+ if (self_disconnected || reason == WLAN_REASON_DISASSOC_STA_HAS_LEFT) {
|
|
|
ifsta->state = IEEE80211_STA_MLME_DISABLED;
|
|
|
+ ieee80211_rx_bss_remove(sdata, ifsta->bssid,
|
|
|
+ sdata->local->hw.conf.channel->center_freq,
|
|
|
+ ifsta->ssid, ifsta->ssid_len);
|
|
|
+ }
|
|
|
|
|
|
rcu_read_unlock();
|
|
|
|
|
@@ -1017,6 +1032,9 @@ static void ieee80211_associate(struct ieee80211_sub_if_data *sdata,
|
|
|
sdata->dev->name, ifsta->bssid);
|
|
|
ifsta->state = IEEE80211_STA_MLME_DISABLED;
|
|
|
ieee80211_sta_send_apinfo(sdata, ifsta);
|
|
|
+ ieee80211_rx_bss_remove(sdata, ifsta->bssid,
|
|
|
+ sdata->local->hw.conf.channel->center_freq,
|
|
|
+ ifsta->ssid, ifsta->ssid_len);
|
|
|
return;
|
|
|
}
|
|
|
|
|
@@ -1042,7 +1060,6 @@ static void ieee80211_associated(struct ieee80211_sub_if_data *sdata,
|
|
|
struct ieee80211_local *local = sdata->local;
|
|
|
struct sta_info *sta;
|
|
|
int disassoc;
|
|
|
- bool remove_bss = false;
|
|
|
|
|
|
/* TODO: start monitoring current AP signal quality and number of
|
|
|
* missed beacons. Scan other channels every now and then and search
|
|
@@ -1068,7 +1085,6 @@ static void ieee80211_associated(struct ieee80211_sub_if_data *sdata,
|
|
|
"range\n",
|
|
|
sdata->dev->name, ifsta->bssid);
|
|
|
disassoc = 1;
|
|
|
- remove_bss = true;
|
|
|
} else
|
|
|
ieee80211_send_probe_req(sdata, ifsta->bssid,
|
|
|
ifsta->ssid,
|
|
@@ -1088,24 +1104,12 @@ static void ieee80211_associated(struct ieee80211_sub_if_data *sdata,
|
|
|
|
|
|
rcu_read_unlock();
|
|
|
|
|
|
- if (disassoc) {
|
|
|
+ if (disassoc)
|
|
|
ieee80211_set_disassoc(sdata, ifsta, true, true,
|
|
|
WLAN_REASON_PREV_AUTH_NOT_VALID);
|
|
|
- if (remove_bss) {
|
|
|
- struct ieee80211_bss *bss;
|
|
|
-
|
|
|
- bss = ieee80211_rx_bss_get(local, ifsta->bssid,
|
|
|
- local->hw.conf.channel->center_freq,
|
|
|
- ifsta->ssid, ifsta->ssid_len);
|
|
|
- if (bss) {
|
|
|
- atomic_dec(&bss->users);
|
|
|
- ieee80211_rx_bss_put(local, bss);
|
|
|
- }
|
|
|
- }
|
|
|
- } else {
|
|
|
+ else
|
|
|
mod_timer(&ifsta->timer, jiffies +
|
|
|
IEEE80211_MONITORING_INTERVAL);
|
|
|
- }
|
|
|
}
|
|
|
|
|
|
|