summaryrefslogtreecommitdiff
path: root/kernel/rcu
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@gmail.com>2019-09-03 21:25:45 +0800
committerJens Axboe <axboe@kernel.dk>2019-09-03 08:08:31 -0600
commita22a9602b88fabf10847f238ff81fde5f906fef7 (patch)
treecdda0a4f2abcfaf8627fec61a16de34e19a2223b /kernel/rcu
parentd66c9920c0cf984cf99cab5036fd5f3a1b7fba46 (diff)
closures: fix a race on wakeup from closure_sync
The race was when a thread using closure_sync() notices cl->s->done == 1 before the thread calling closure_put() calls wake_up_process(). Then, it's possible for that thread to return and exit just before wake_up_process() is called - so we're trying to wake up a process that no longer exists. rcu_read_lock() is sufficient to protect against this, as there's an rcu barrier somewhere in the process teardown path. Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com> Acked-by: Coly Li <colyli@suse.de> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'kernel/rcu')
0 files changed, 0 insertions, 0 deletions