diff options
-rw-r--r-- | drivers/net/wireless/wl1251/ps.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/net/wireless/wl1251/ps.c b/drivers/net/wireless/wl1251/ps.c index 842155e65a8..9cc514703d2 100644 --- a/drivers/net/wireless/wl1251/ps.c +++ b/drivers/net/wireless/wl1251/ps.c | |||
@@ -58,7 +58,6 @@ void wl1251_ps_elp_sleep(struct wl1251 *wl) | |||
58 | unsigned long delay; | 58 | unsigned long delay; |
59 | 59 | ||
60 | if (wl->psm) { | 60 | if (wl->psm) { |
61 | cancel_delayed_work(&wl->elp_work); | ||
62 | delay = msecs_to_jiffies(ELP_ENTRY_DELAY); | 61 | delay = msecs_to_jiffies(ELP_ENTRY_DELAY); |
63 | ieee80211_queue_delayed_work(wl->hw, &wl->elp_work, delay); | 62 | ieee80211_queue_delayed_work(wl->hw, &wl->elp_work, delay); |
64 | } | 63 | } |
@@ -69,6 +68,9 @@ int wl1251_ps_elp_wakeup(struct wl1251 *wl) | |||
69 | unsigned long timeout, start; | 68 | unsigned long timeout, start; |
70 | u32 elp_reg; | 69 | u32 elp_reg; |
71 | 70 | ||
71 | if (delayed_work_pending(&wl->elp_work)) | ||
72 | cancel_delayed_work(&wl->elp_work); | ||
73 | |||
72 | if (!wl->elp) | 74 | if (!wl->elp) |
73 | return 0; | 75 | return 0; |
74 | 76 | ||