]> git.baikalelectronics.ru Git - kernel.git/commit
sbitmap: fix wakeup hang after sbq resize
authorOmar Sandoval <osandov@fb.com>
Wed, 18 Jan 2017 19:55:22 +0000 (11:55 -0800)
committerJens Axboe <axboe@fb.com>
Wed, 18 Jan 2017 20:41:55 +0000 (13:41 -0700)
commita40c17a9a492ac99320bd105f656e97d7e25042e
treebbe47f1b91edbae94b582649b7d11a4b2b2fb877
parente340ca8129d43cde7b3dbe4a5d3e668c46358b18
sbitmap: fix wakeup hang after sbq resize

When we resize a struct sbitmap_queue, we update the wakeup batch size,
but we don't update the wait count in the struct sbq_wait_states. If we
resized down from a size which could use a bigger batch size, these
counts could be too large and cause us to miss necessary wakeups. To fix
this, update the wait counts when we resize (ensuring some careful
memory ordering so that it's safe w.r.t. concurrent clears).

This also fixes a theoretical issue where two threads could end up
bumping the wait count up by the batch size, which could also
potentially lead to hangs.

Reported-by: Martin Raiber <martin@urbackup.org>
Fixes: b0bf9f880938 ("blk-mq: allow changing of queue depth through sysfs")
Fixes: 7b6d6df9cb32 ("blk-mq: bitmap tag: fix race on blk_mq_bitmap_tags::wake_cnt")
Signed-off-by: Omar Sandoval <osandov@fb.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
lib/sbitmap.c