Skip to content

Commit 1fad17f

Browse files
vireshkrafaeljw
authored andcommitted
PM / wakeup: Rework wakeup source timer cancellation
If wakeup_source_add() is called right after wakeup_source_remove() for the same wakeup source, timer_setup() may be called for a potentially scheduled timer which is incorrect. To avoid that, move the wakeup source timer cancellation from wakeup_source_drop() to wakeup_source_remove(). Moreover, make wakeup_source_remove() clear the timer function after canceling the timer to let wakeup_source_not_registered() treat unregistered wakeup sources in the same way as the ones that have never been registered. Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> Cc: 4.4+ <stable@vger.kernel.org> # 4.4+ [ rjw: Subject, changelog, merged two patches together ] Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
1 parent ef80068 commit 1fad17f

File tree

1 file changed

+7
-1
lines changed

1 file changed

+7
-1
lines changed

drivers/base/power/wakeup.c

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -118,7 +118,6 @@ void wakeup_source_drop(struct wakeup_source *ws)
118118
if (!ws)
119119
return;
120120

121-
del_timer_sync(&ws->timer);
122121
__pm_relax(ws);
123122
}
124123
EXPORT_SYMBOL_GPL(wakeup_source_drop);
@@ -205,6 +204,13 @@ void wakeup_source_remove(struct wakeup_source *ws)
205204
list_del_rcu(&ws->entry);
206205
raw_spin_unlock_irqrestore(&events_lock, flags);
207206
synchronize_srcu(&wakeup_srcu);
207+
208+
del_timer_sync(&ws->timer);
209+
/*
210+
* Clear timer.function to make wakeup_source_not_registered() treat
211+
* this wakeup source as not registered.
212+
*/
213+
ws->timer.function = NULL;
208214
}
209215
EXPORT_SYMBOL_GPL(wakeup_source_remove);
210216

0 commit comments

Comments
 (0)