mac80211: fix IEEE80211_SDATA_DISCONNECT_RESUME
Since commit12e7f51702
, IEEE80211_SDATA_DISCONNECT_RESUME no longer worked as it would simply never be tested. Restore a bit of the code removed there and in9b7d72c104
to make it work again. Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
a92eecbbea
commit
b8360ab8d2
@ -1267,6 +1267,7 @@ void ieee80211_sta_reset_conn_monitor(struct ieee80211_sub_if_data *sdata);
|
|||||||
void ieee80211_mgd_stop(struct ieee80211_sub_if_data *sdata);
|
void ieee80211_mgd_stop(struct ieee80211_sub_if_data *sdata);
|
||||||
void ieee80211_mgd_conn_tx_status(struct ieee80211_sub_if_data *sdata,
|
void ieee80211_mgd_conn_tx_status(struct ieee80211_sub_if_data *sdata,
|
||||||
__le16 fc, bool acked);
|
__le16 fc, bool acked);
|
||||||
|
void ieee80211_sta_restart(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);
|
||||||
|
@ -3623,6 +3623,31 @@ static void ieee80211_restart_sta_timer(struct ieee80211_sub_if_data *sdata)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_PM
|
||||||
|
void ieee80211_sta_restart(struct ieee80211_sub_if_data *sdata)
|
||||||
|
{
|
||||||
|
struct ieee80211_if_managed *ifmgd = &sdata->u.mgd;
|
||||||
|
|
||||||
|
mutex_lock(&ifmgd->mtx);
|
||||||
|
if (!ifmgd->associated) {
|
||||||
|
mutex_unlock(&ifmgd->mtx);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sdata->flags & IEEE80211_SDATA_DISCONNECT_RESUME) {
|
||||||
|
sdata->flags &= ~IEEE80211_SDATA_DISCONNECT_RESUME;
|
||||||
|
mlme_dbg(sdata, "driver requested disconnect after resume\n");
|
||||||
|
ieee80211_sta_connection_lost(sdata,
|
||||||
|
ifmgd->associated->bssid,
|
||||||
|
WLAN_REASON_UNSPECIFIED,
|
||||||
|
true);
|
||||||
|
mutex_unlock(&ifmgd->mtx);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mutex_unlock(&ifmgd->mtx);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* interface setup */
|
/* interface setup */
|
||||||
void ieee80211_sta_setup_sdata(struct ieee80211_sub_if_data *sdata)
|
void ieee80211_sta_setup_sdata(struct ieee80211_sub_if_data *sdata)
|
||||||
{
|
{
|
||||||
|
@ -1740,6 +1740,13 @@ int ieee80211_reconfig(struct ieee80211_local *local)
|
|||||||
mb();
|
mb();
|
||||||
local->resuming = false;
|
local->resuming = false;
|
||||||
|
|
||||||
|
list_for_each_entry(sdata, &local->interfaces, list) {
|
||||||
|
if (!ieee80211_sdata_running(sdata))
|
||||||
|
continue;
|
||||||
|
if (sdata->vif.type == NL80211_IFTYPE_STATION)
|
||||||
|
ieee80211_sta_restart(sdata);
|
||||||
|
}
|
||||||
|
|
||||||
mod_timer(&local->sta_cleanup, jiffies + 1);
|
mod_timer(&local->sta_cleanup, jiffies + 1);
|
||||||
#else
|
#else
|
||||||
WARN_ON(1);
|
WARN_ON(1);
|
||||||
|
Loading…
Reference in New Issue
Block a user