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

mac80211: clean up station cleanup timer

We currently run this timer exactly once when
a new mac80211 device is registered, but that
is completely pointless since it will have no
work to do at all. Therefore, remove that and
also simplify some code using the timer.
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent ccc7c28a
...@@ -879,10 +879,6 @@ int ieee80211_register_hw(struct ieee80211_hw *hw) ...@@ -879,10 +879,6 @@ int ieee80211_register_hw(struct ieee80211_hw *hw)
local->dynamic_ps_forced_timeout = -1; local->dynamic_ps_forced_timeout = -1;
result = sta_info_start(local);
if (result < 0)
goto fail_sta_info;
result = ieee80211_wep_init(local); result = ieee80211_wep_init(local);
if (result < 0) if (result < 0)
wiphy_debug(local->hw.wiphy, "Failed to initialize wep: %d\n", wiphy_debug(local->hw.wiphy, "Failed to initialize wep: %d\n",
...@@ -945,7 +941,6 @@ int ieee80211_register_hw(struct ieee80211_hw *hw) ...@@ -945,7 +941,6 @@ int ieee80211_register_hw(struct ieee80211_hw *hw)
rtnl_unlock(); rtnl_unlock();
ieee80211_wep_free(local); ieee80211_wep_free(local);
sta_info_stop(local); sta_info_stop(local);
fail_sta_info:
destroy_workqueue(local->workqueue); destroy_workqueue(local->workqueue);
fail_workqueue: fail_workqueue:
wiphy_unregister(local->hw.wiphy); wiphy_unregister(local->hw.wiphy);
......
...@@ -768,9 +768,8 @@ static void sta_info_cleanup(unsigned long data) ...@@ -768,9 +768,8 @@ static void sta_info_cleanup(unsigned long data)
if (!timer_needed) if (!timer_needed)
return; return;
local->sta_cleanup.expires = mod_timer(&local->sta_cleanup,
round_jiffies(jiffies + STA_INFO_CLEANUP_INTERVAL); round_jiffies(jiffies + STA_INFO_CLEANUP_INTERVAL));
add_timer(&local->sta_cleanup);
} }
void sta_info_init(struct ieee80211_local *local) void sta_info_init(struct ieee80211_local *local)
...@@ -783,14 +782,6 @@ void sta_info_init(struct ieee80211_local *local) ...@@ -783,14 +782,6 @@ void sta_info_init(struct ieee80211_local *local)
setup_timer(&local->sta_cleanup, sta_info_cleanup, setup_timer(&local->sta_cleanup, sta_info_cleanup,
(unsigned long)local); (unsigned long)local);
local->sta_cleanup.expires =
round_jiffies(jiffies + STA_INFO_CLEANUP_INTERVAL);
}
int sta_info_start(struct ieee80211_local *local)
{
add_timer(&local->sta_cleanup);
return 0;
} }
void sta_info_stop(struct ieee80211_local *local) void sta_info_stop(struct ieee80211_local *local)
......
...@@ -497,7 +497,6 @@ void sta_info_set_tim_bit(struct sta_info *sta); ...@@ -497,7 +497,6 @@ void sta_info_set_tim_bit(struct sta_info *sta);
void sta_info_clear_tim_bit(struct sta_info *sta); void sta_info_clear_tim_bit(struct sta_info *sta);
void sta_info_init(struct ieee80211_local *local); void sta_info_init(struct ieee80211_local *local);
int sta_info_start(struct ieee80211_local *local);
void sta_info_stop(struct ieee80211_local *local); void sta_info_stop(struct ieee80211_local *local);
int sta_info_flush(struct ieee80211_local *local, int sta_info_flush(struct ieee80211_local *local,
struct ieee80211_sub_if_data *sdata); struct ieee80211_sub_if_data *sdata);
......
...@@ -1290,7 +1290,7 @@ int ieee80211_reconfig(struct ieee80211_local *local) ...@@ -1290,7 +1290,7 @@ int ieee80211_reconfig(struct ieee80211_local *local)
} }
} }
add_timer(&local->sta_cleanup); mod_timer(&local->sta_cleanup, jiffies + 1);
mutex_lock(&local->sta_mtx); mutex_lock(&local->sta_mtx);
list_for_each_entry(sta, &local->sta_list, list) list_for_each_entry(sta, &local->sta_list, list)
......
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