* [PATCH] mac80211: acquire sta_lock for station suspend/resume
@ 2009-03-14 8:42 Johannes Berg
2009-03-14 23:40 ` Bob Copeland
0 siblings, 1 reply; 2+ messages in thread
From: Johannes Berg @ 2009-03-14 8:42 UTC (permalink / raw)
To: John Linville; +Cc: Bob Copeland, linux-wireless
To avoid concurrent manipulations of the sta list (which shouldn't
be possible at this point, but anyway) we need to hold the sta_lock
around iterating the list.
At the same time, we do not need to iterate the list at all if
the driver doesn't want to be notified.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
---
net/mac80211/pm.c | 18 ++++++++++--------
1 file changed, 10 insertions(+), 8 deletions(-)
--- wireless-testing.orig/net/mac80211/pm.c 2009-03-14 09:35:01.000000000 +0100
+++ wireless-testing/net/mac80211/pm.c 2009-03-14 09:40:12.000000000 +0100
@@ -10,6 +10,7 @@ int __ieee80211_suspend(struct ieee80211
struct ieee80211_sub_if_data *sdata;
struct ieee80211_if_init_conf conf;
struct sta_info *sta;
+ unsigned long flags;
ieee80211_stop_queues_by_reason(hw,
IEEE80211_QUEUE_STOP_REASON_SUSPEND);
@@ -21,9 +22,9 @@ int __ieee80211_suspend(struct ieee80211
ieee80211_disable_keys(sdata);
/* remove STAs */
- list_for_each_entry(sta, &local->sta_list, list) {
-
- if (local->ops->sta_notify) {
+ if (local->ops->sta_notify) {
+ spin_lock_irqsave(&local->sta_lock, flags);
+ list_for_each_entry(sta, &local->sta_list, list) {
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
@@ -32,11 +33,11 @@ int __ieee80211_suspend(struct ieee80211
local->ops->sta_notify(hw, &sdata->vif,
STA_NOTIFY_REMOVE, &sta->sta);
}
+ spin_unlock_irqrestore(&local->sta_lock, flags);
}
/* remove all interfaces */
list_for_each_entry(sdata, &local->interfaces, list) {
-
if (sdata->vif.type != NL80211_IFTYPE_AP_VLAN &&
sdata->vif.type != NL80211_IFTYPE_MONITOR &&
netif_running(sdata->dev)) {
@@ -64,6 +65,7 @@ int __ieee80211_resume(struct ieee80211_
struct ieee80211_sub_if_data *sdata;
struct ieee80211_if_init_conf conf;
struct sta_info *sta;
+ unsigned long flags;
int res;
/* restart hardware */
@@ -75,7 +77,6 @@ int __ieee80211_resume(struct ieee80211_
/* add interfaces */
list_for_each_entry(sdata, &local->interfaces, list) {
-
if (sdata->vif.type != NL80211_IFTYPE_AP_VLAN &&
sdata->vif.type != NL80211_IFTYPE_MONITOR &&
netif_running(sdata->dev)) {
@@ -87,9 +88,9 @@ int __ieee80211_resume(struct ieee80211_
}
/* add STAs back */
- list_for_each_entry(sta, &local->sta_list, list) {
-
- if (local->ops->sta_notify) {
+ if (local->ops->sta_notify) {
+ spin_lock_irqsave(&local->sta_lock, flags);
+ list_for_each_entry(sta, &local->sta_list, list) {
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
@@ -98,6 +99,7 @@ int __ieee80211_resume(struct ieee80211_
local->ops->sta_notify(hw, &sdata->vif,
STA_NOTIFY_ADD, &sta->sta);
}
+ spin_unlock_irqrestore(&local->sta_lock, flags);
}
/* add back keys */
^ permalink raw reply [flat|nested] 2+ messages in thread* Re: [PATCH] mac80211: acquire sta_lock for station suspend/resume
2009-03-14 8:42 [PATCH] mac80211: acquire sta_lock for station suspend/resume Johannes Berg
@ 2009-03-14 23:40 ` Bob Copeland
0 siblings, 0 replies; 2+ messages in thread
From: Bob Copeland @ 2009-03-14 23:40 UTC (permalink / raw)
To: Johannes Berg; +Cc: John Linville, linux-wireless
On Sat, Mar 14, 2009 at 4:42 AM, Johannes Berg
<johannes@sipsolutions.net> wrote:
> To avoid concurrent manipulations of the sta list (which shouldn't
> be possible at this point, but anyway) we need to hold the sta_lock
> around iterating the list.
>
> At the same time, we do not need to iterate the list at all if
> the driver doesn't want to be notified.
>
> Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Acked-by: Bob Copeland <me@bobcopeland.com>
--
Bob Copeland %% www.bobcopeland.com
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2009-03-14 23:40 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-03-14 8:42 [PATCH] mac80211: acquire sta_lock for station suspend/resume Johannes Berg
2009-03-14 23:40 ` Bob Copeland
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox