|
@@ -885,7 +885,6 @@ void sta_info_init(struct ieee80211_local *local)
|
|
|
void sta_info_stop(struct ieee80211_local *local)
|
|
|
{
|
|
|
del_timer_sync(&local->sta_cleanup);
|
|
|
- sta_info_flush(local, NULL);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -893,12 +892,11 @@ void sta_info_stop(struct ieee80211_local *local)
|
|
|
*
|
|
|
* Returns the number of removed STA entries.
|
|
|
*
|
|
|
- * @local: local interface data
|
|
|
- * @sdata: matching rule for the net device (sta->dev) or %NULL to match all STAs
|
|
|
+ * @sdata: sdata to remove all stations from
|
|
|
*/
|
|
|
-int sta_info_flush(struct ieee80211_local *local,
|
|
|
- struct ieee80211_sub_if_data *sdata)
|
|
|
+int sta_info_flush(struct ieee80211_sub_if_data *sdata)
|
|
|
{
|
|
|
+ struct ieee80211_local *local = sdata->local;
|
|
|
struct sta_info *sta, *tmp;
|
|
|
int ret = 0;
|
|
|
|
|
@@ -906,7 +904,7 @@ int sta_info_flush(struct ieee80211_local *local,
|
|
|
|
|
|
mutex_lock(&local->sta_mtx);
|
|
|
list_for_each_entry_safe(sta, tmp, &local->sta_list, list) {
|
|
|
- if (!sdata || sdata == sta->sdata) {
|
|
|
+ if (sdata == sta->sdata) {
|
|
|
WARN_ON(__sta_info_destroy(sta));
|
|
|
ret++;
|
|
|
}
|
|
@@ -915,17 +913,8 @@ int sta_info_flush(struct ieee80211_local *local,
|
|
|
|
|
|
rcu_barrier();
|
|
|
|
|
|
- if (sdata) {
|
|
|
- ieee80211_cleanup_sdata_stas(sdata);
|
|
|
- cancel_work_sync(&sdata->cleanup_stations_wk);
|
|
|
- } else {
|
|
|
- mutex_lock(&local->iflist_mtx);
|
|
|
- list_for_each_entry(sdata, &local->interfaces, list) {
|
|
|
- ieee80211_cleanup_sdata_stas(sdata);
|
|
|
- cancel_work_sync(&sdata->cleanup_stations_wk);
|
|
|
- }
|
|
|
- mutex_unlock(&local->iflist_mtx);
|
|
|
- }
|
|
|
+ ieee80211_cleanup_sdata_stas(sdata);
|
|
|
+ cancel_work_sync(&sdata->cleanup_stations_wk);
|
|
|
|
|
|
return ret;
|
|
|
}
|