Commit b291ba11 authored by Johannes Berg's avatar Johannes Berg Committed by John W. Linville

mac80211: monitor the connection

With the recent MLME rework I accidentally removed the connection
monitoring code. In order to add it back, this patch will add new
code to monitor both for beacon loss and for the connection actually
working, with possibly separate triggers.

When no unicast frames have been received from the AP for (currently)
two seconds, we will send the AP a probe request. Also, when we don't
see beacons from the AP for two seconds, we do the same (but those
times need not be the same due to the way the code is now written).

Additionally, clean up the parameters to the ieee80211_set_disassoc()
function that I need here, those are all useless except sdata.
Signed-off-by: default avatarJohannes Berg <johannes@sipsolutions.net>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent ca386f31
...@@ -256,12 +256,13 @@ struct ieee80211_mgd_work { ...@@ -256,12 +256,13 @@ struct ieee80211_mgd_work {
/* flags used in struct ieee80211_if_managed.flags */ /* flags used in struct ieee80211_if_managed.flags */
enum ieee80211_sta_flags { enum ieee80211_sta_flags {
IEEE80211_STA_PROBEREQ_POLL = BIT(3), IEEE80211_STA_BEACON_POLL = BIT(0),
IEEE80211_STA_CONTROL_PORT = BIT(4), IEEE80211_STA_CONNECTION_POLL = BIT(1),
IEEE80211_STA_WMM_ENABLED = BIT(5), IEEE80211_STA_CONTROL_PORT = BIT(2),
IEEE80211_STA_DISABLE_11N = BIT(6), IEEE80211_STA_WMM_ENABLED = BIT(3),
IEEE80211_STA_CSA_RECEIVED = BIT(7), IEEE80211_STA_DISABLE_11N = BIT(4),
IEEE80211_STA_MFP_ENABLED = BIT(8), IEEE80211_STA_CSA_RECEIVED = BIT(5),
IEEE80211_STA_MFP_ENABLED = BIT(6),
}; };
/* flags for MLME request */ /* flags for MLME request */
...@@ -271,11 +272,16 @@ enum ieee80211_sta_request { ...@@ -271,11 +272,16 @@ enum ieee80211_sta_request {
struct ieee80211_if_managed { struct ieee80211_if_managed {
struct timer_list timer; struct timer_list timer;
struct timer_list conn_mon_timer;
struct timer_list bcn_mon_timer;
struct timer_list chswitch_timer; struct timer_list chswitch_timer;
struct work_struct work; struct work_struct work;
struct work_struct monitor_work;
struct work_struct chswitch_work; struct work_struct chswitch_work;
struct work_struct beacon_loss_work; struct work_struct beacon_loss_work;
unsigned long probe_timeout;
struct mutex mtx; struct mutex mtx;
struct ieee80211_bss *associated; struct ieee80211_bss *associated;
struct list_head work_list; struct list_head work_list;
...@@ -292,8 +298,6 @@ struct ieee80211_if_managed { ...@@ -292,8 +298,6 @@ struct ieee80211_if_managed {
unsigned long request; unsigned long request;
unsigned long last_beacon;
unsigned int flags; unsigned int flags;
u32 beacon_crc; u32 beacon_crc;
......
This diff is collapsed.
...@@ -833,28 +833,22 @@ ieee80211_rx_h_sta_process(struct ieee80211_rx_data *rx) ...@@ -833,28 +833,22 @@ ieee80211_rx_h_sta_process(struct ieee80211_rx_data *rx)
if (!sta) if (!sta)
return RX_CONTINUE; return RX_CONTINUE;
/* Update last_rx only for IBSS packets which are for the current /*
* BSSID to avoid keeping the current IBSS network alive in cases where * Update last_rx only for IBSS packets which are for the current
* other STAs are using different BSSID. */ * BSSID to avoid keeping the current IBSS network alive in cases
* where other STAs start using different BSSID.
*/
if (rx->sdata->vif.type == NL80211_IFTYPE_ADHOC) { if (rx->sdata->vif.type == NL80211_IFTYPE_ADHOC) {
u8 *bssid = ieee80211_get_bssid(hdr, rx->skb->len, u8 *bssid = ieee80211_get_bssid(hdr, rx->skb->len,
NL80211_IFTYPE_ADHOC); NL80211_IFTYPE_ADHOC);
if (compare_ether_addr(bssid, rx->sdata->u.ibss.bssid) == 0) if (compare_ether_addr(bssid, rx->sdata->u.ibss.bssid) == 0)
sta->last_rx = jiffies; sta->last_rx = jiffies;
} else } else if (!is_multicast_ether_addr(hdr->addr1)) {
if (!is_multicast_ether_addr(hdr->addr1) || /*
rx->sdata->vif.type == NL80211_IFTYPE_STATION) {
/* Update last_rx only for unicast frames in order to prevent
* the Probe Request frames (the only broadcast frames from a
* STA in infrastructure mode) from keeping a connection alive.
* Mesh beacons will update last_rx when if they are found to * Mesh beacons will update last_rx when if they are found to
* match the current local configuration when processed. * match the current local configuration when processed.
*/ */
if (rx->sdata->vif.type == NL80211_IFTYPE_STATION && sta->last_rx = jiffies;
ieee80211_is_beacon(hdr->frame_control)) {
rx->sdata->u.mgd.last_beacon = jiffies;
} else
sta->last_rx = jiffies;
} }
if (!(rx->flags & IEEE80211_RX_RA_MATCH)) if (!(rx->flags & IEEE80211_RX_RA_MATCH))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment