mac80211: add helper for reseting the connection monitor
This will be used in another place later. The connection monitor was added as of 2.6.35 so these fixes will be applicable to >= 2.6.35. Cc: stable@kernel.org Cc: Paul Stewart <pstew@google.com> Cc: Amod Bodas <amod.bodas@atheros.com> Signed-off-by: Luis R. Rodriguez <lrodriguez@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
Родитель
48a6a46819
Коммит
be099e82e9
|
@ -1041,6 +1041,7 @@ void ieee80211_sta_restart(struct ieee80211_sub_if_data *sdata);
|
||||||
void ieee80211_sta_work(struct ieee80211_sub_if_data *sdata);
|
void ieee80211_sta_work(struct ieee80211_sub_if_data *sdata);
|
||||||
void ieee80211_sta_rx_queued_mgmt(struct ieee80211_sub_if_data *sdata,
|
void ieee80211_sta_rx_queued_mgmt(struct ieee80211_sub_if_data *sdata,
|
||||||
struct sk_buff *skb);
|
struct sk_buff *skb);
|
||||||
|
void ieee80211_sta_reset_conn_monitor(struct ieee80211_sub_if_data *sdata);
|
||||||
|
|
||||||
/* IBSS code */
|
/* IBSS code */
|
||||||
void ieee80211_ibss_notify_scan_completed(struct ieee80211_local *local);
|
void ieee80211_ibss_notify_scan_completed(struct ieee80211_local *local);
|
||||||
|
|
|
@ -124,6 +124,15 @@ static void mod_beacon_timer(struct ieee80211_sub_if_data *sdata)
|
||||||
round_jiffies_up(jiffies + IEEE80211_BEACON_LOSS_TIME));
|
round_jiffies_up(jiffies + IEEE80211_BEACON_LOSS_TIME));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ieee80211_sta_reset_conn_monitor(struct ieee80211_sub_if_data *sdata)
|
||||||
|
{
|
||||||
|
if (sdata->local->hw.flags & IEEE80211_HW_CONNECTION_MONITOR)
|
||||||
|
return;
|
||||||
|
|
||||||
|
mod_timer(&sdata->u.mgd.conn_mon_timer,
|
||||||
|
round_jiffies_up(jiffies + IEEE80211_CONNECTION_IDLE_TIME));
|
||||||
|
}
|
||||||
|
|
||||||
static int ecw2cw(int ecw)
|
static int ecw2cw(int ecw)
|
||||||
{
|
{
|
||||||
return (1 << ecw) - 1;
|
return (1 << ecw) - 1;
|
||||||
|
@ -1018,11 +1027,7 @@ void ieee80211_sta_rx_notify(struct ieee80211_sub_if_data *sdata,
|
||||||
if (is_multicast_ether_addr(hdr->addr1))
|
if (is_multicast_ether_addr(hdr->addr1))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (sdata->local->hw.flags & IEEE80211_HW_CONNECTION_MONITOR)
|
ieee80211_sta_reset_conn_monitor(sdata);
|
||||||
return;
|
|
||||||
|
|
||||||
mod_timer(&sdata->u.mgd.conn_mon_timer,
|
|
||||||
round_jiffies_up(jiffies + IEEE80211_CONNECTION_IDLE_TIME));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ieee80211_mgd_probe_ap_send(struct ieee80211_sub_if_data *sdata)
|
static void ieee80211_mgd_probe_ap_send(struct ieee80211_sub_if_data *sdata)
|
||||||
|
|
Загрузка…
Ссылка в новой задаче