Commit 61e8a48c authored by Johannes Berg's avatar Johannes Berg

mac80211: clean up ieee80211_quiesce

It's a bit odd that there's a return value that only
depends on the iftype, move that logic out of the
function into the only caller that needs it.

Also, since the quiescing could stop timers that
trigger the sdata work, move the sdata work cancel
into the function and after the actual quiesce.

Finally, there's no need to call it on interfaces
that are down, so don't.

Change-Id: I1632d46d21ba3558ea713d035184f1939905f2f1
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent d45c4172
...@@ -7,25 +7,23 @@ ...@@ -7,25 +7,23 @@
#include "led.h" #include "led.h"
/* return value indicates whether the driver should be further notified */ /* return value indicates whether the driver should be further notified */
static bool ieee80211_quiesce(struct ieee80211_sub_if_data *sdata) static void ieee80211_quiesce(struct ieee80211_sub_if_data *sdata)
{ {
switch (sdata->vif.type) { switch (sdata->vif.type) {
case NL80211_IFTYPE_STATION: case NL80211_IFTYPE_STATION:
ieee80211_sta_quiesce(sdata); ieee80211_sta_quiesce(sdata);
return true; break;
case NL80211_IFTYPE_ADHOC: case NL80211_IFTYPE_ADHOC:
ieee80211_ibss_quiesce(sdata); ieee80211_ibss_quiesce(sdata);
return true; break;
case NL80211_IFTYPE_MESH_POINT: case NL80211_IFTYPE_MESH_POINT:
ieee80211_mesh_quiesce(sdata); ieee80211_mesh_quiesce(sdata);
return true; break;
case NL80211_IFTYPE_AP_VLAN:
case NL80211_IFTYPE_MONITOR:
/* don't tell driver about this */
return false;
default: default:
return true; break;
} }
cancel_work_sync(&sdata->work);
} }
int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan) int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan)
...@@ -94,10 +92,9 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan) ...@@ -94,10 +92,9 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan)
WARN_ON(err != 1); WARN_ON(err != 1);
local->wowlan = false; local->wowlan = false;
} else { } else {
list_for_each_entry(sdata, &local->interfaces, list) { list_for_each_entry(sdata, &local->interfaces, list)
cancel_work_sync(&sdata->work); if (ieee80211_sdata_running(sdata))
ieee80211_quiesce(sdata); ieee80211_quiesce(sdata);
}
goto suspend; goto suspend;
} }
} }
...@@ -124,13 +121,18 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan) ...@@ -124,13 +121,18 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan)
/* remove all interfaces */ /* remove all interfaces */
list_for_each_entry(sdata, &local->interfaces, list) { list_for_each_entry(sdata, &local->interfaces, list) {
cancel_work_sync(&sdata->work); if (!ieee80211_sdata_running(sdata))
if (!ieee80211_quiesce(sdata))
continue; continue;
if (!ieee80211_sdata_running(sdata)) switch (sdata->vif.type) {
case NL80211_IFTYPE_AP_VLAN:
case NL80211_IFTYPE_MONITOR:
/* skip these */
continue; continue;
default:
ieee80211_quiesce(sdata);
break;
}
/* disable beaconing */ /* disable beaconing */
ieee80211_bss_info_change_notify(sdata, ieee80211_bss_info_change_notify(sdata,
......
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