summaryrefslogtreecommitdiff
path: root/lib/lockref.c
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2018-03-22 08:56:06 +0100
committerTakashi Iwai <tiwai@suse.de>2018-03-22 10:34:12 +0100
commit67a01afaf3d34893cf7d2ea19b34555d6abb7cb0 (patch)
treeb499d7415039119c5bc6441d9ac2ed416fba70b8 /lib/lockref.c
parent88d42b2b45d7208cc872c2c9dec0b1ae6c6008d7 (diff)
ALSA: aloop: Sync stale timer before release
The aloop driver tries to stop the pending timer via timer_del() in the trigger callback and in the close callback. The former is correct, as it's an atomic operation, while the latter expects that the timer gets really removed and proceeds the resource releases after that. But timer_del() doesn't synchronize, hence the running timer may still access the released resources. A similar situation can be also seen in the prepare callback after trigger(STOP) where the prepare tries to re-initialize the things while a timer is still running. The problems like the above are seen indirectly in some syzkaller reports (although it's not 100% clear whether this is the only cause, as the race condition is quite narrow and not always easy to trigger). For addressing these issues, this patch adds the explicit alls of timer_del_sync() in some places, so that the pending timer is properly killed / synced. Cc: <stable@vger.kernel.org> Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'lib/lockref.c')
0 files changed, 0 insertions, 0 deletions