diff options
| author | Johannes Berg <johannes@sipsolutions.net> | 2009-03-13 06:43:36 -0400 |
|---|---|---|
| committer | John W. Linville <linville@tuxdriver.com> | 2009-03-27 20:12:52 -0400 |
| commit | 25420604c8967ff24f087dd7b9cd4b278567d39a (patch) | |
| tree | b5a1c0edcca74cf64abce8bd6699774c0c387838 | |
| parent | b5bde374f0f61f5d97114d400ade8fc96bf6f10d (diff) | |
mac80211: stop queues across suspend/resume
Even though userland probably cannot submit packets, there might
still be some coming, and that's no good when the driver doesn't
expect them. Stop the queues across suspend/resume.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
| -rw-r--r-- | net/mac80211/ieee80211_i.h | 1 | ||||
| -rw-r--r-- | net/mac80211/pm.c | 6 |
2 files changed, 7 insertions, 0 deletions
diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h index fbb91f1aebb2..ad12c2a03a95 100644 --- a/net/mac80211/ieee80211_i.h +++ b/net/mac80211/ieee80211_i.h | |||
| @@ -598,6 +598,7 @@ enum queue_stop_reason { | |||
| 598 | IEEE80211_QUEUE_STOP_REASON_PS, | 598 | IEEE80211_QUEUE_STOP_REASON_PS, |
| 599 | IEEE80211_QUEUE_STOP_REASON_CSA, | 599 | IEEE80211_QUEUE_STOP_REASON_CSA, |
| 600 | IEEE80211_QUEUE_STOP_REASON_AGGREGATION, | 600 | IEEE80211_QUEUE_STOP_REASON_AGGREGATION, |
| 601 | IEEE80211_QUEUE_STOP_REASON_SUSPEND, | ||
| 601 | }; | 602 | }; |
| 602 | 603 | ||
| 603 | struct ieee80211_master_priv { | 604 | struct ieee80211_master_priv { |
diff --git a/net/mac80211/pm.c b/net/mac80211/pm.c index 44525f517077..c923ceb089a3 100644 --- a/net/mac80211/pm.c +++ b/net/mac80211/pm.c | |||
| @@ -11,6 +11,9 @@ int __ieee80211_suspend(struct ieee80211_hw *hw) | |||
| 11 | struct ieee80211_if_init_conf conf; | 11 | struct ieee80211_if_init_conf conf; |
| 12 | struct sta_info *sta; | 12 | struct sta_info *sta; |
| 13 | 13 | ||
| 14 | ieee80211_stop_queues_by_reason(hw, | ||
| 15 | IEEE80211_QUEUE_STOP_REASON_SUSPEND); | ||
| 16 | |||
| 14 | flush_workqueue(local->hw.workqueue); | 17 | flush_workqueue(local->hw.workqueue); |
| 15 | 18 | ||
| 16 | /* disable keys */ | 19 | /* disable keys */ |
| @@ -113,5 +116,8 @@ int __ieee80211_resume(struct ieee80211_hw *hw) | |||
| 113 | ieee80211_configure_filter(local); | 116 | ieee80211_configure_filter(local); |
| 114 | netif_addr_unlock_bh(local->mdev); | 117 | netif_addr_unlock_bh(local->mdev); |
| 115 | 118 | ||
| 119 | ieee80211_wake_queues_by_reason(hw, | ||
| 120 | IEEE80211_QUEUE_STOP_REASON_SUSPEND); | ||
| 121 | |||
| 116 | return 0; | 122 | return 0; |
| 117 | } | 123 | } |
