aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/drivers/i2c/algos/i2c-algo-bit.c
diff options
context:
space:
mode:
authorRafael J. Wysocki <rjw@sisk.pl>2012-02-17 23:39:33 +0100
committerRafael J. Wysocki <rjw@sisk.pl>2012-03-04 23:08:14 +0100
commitda863cddd831b0f4bf2d067f8b75254f1be94590 (patch)
treef217486238bec611a0c08b88ae64249ba60a544e /drivers/i2c/algos/i2c-algo-bit.c
parentPM / Sleep: Fix possible infinite loop during wakeup source destruction (diff)
downloadwireguard-linux-da863cddd831b0f4bf2d067f8b75254f1be94590.tar.xz
wireguard-linux-da863cddd831b0f4bf2d067f8b75254f1be94590.zip
PM / Sleep: Fix race conditions related to wakeup source timer function
If __pm_wakeup_event() has been used (with a nonzero timeout) to report a wakeup event and then __pm_relax() immediately followed by __pm_stay_awake() is called or __pm_wakeup_event() is called once again for the same wakeup source object before its timer expires, the timer function pm_wakeup_timer_fn() may still be run as a result of the previous __pm_wakeup_event() call. In either of those cases it may mistakenly deactivate the wakeup source that has just been activated. To prevent that from happening, make wakeup_source_deactivate() clear the wakeup source's timer_expires field and make pm_wakeup_timer_fn() check if timer_expires is different from zero and if it's not in future before calling wakeup_source_deactivate() (if timer_expires is 0, it means that the timer has just been deleted and if timer_expires is in future, it means that the timer has just been rescheduled to a different time). Reported-by: Arve Hjønnevåg <arve@android.com> Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Diffstat (limited to 'drivers/i2c/algos/i2c-algo-bit.c')
0 files changed, 0 insertions, 0 deletions