summaryrefslogtreecommitdiff
path: root/Kbuild
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2014-07-01 10:34:38 -0600
committerJens Axboe <axboe@fb.com>2014-07-01 10:34:38 -0600
commitadd703fda981b9719d37f371498b9f129acbd997 (patch)
tree905e2f2f3a7753536a83f9c4b047e44f039a4bfe /Kbuild
parent72d6f02a8d4e0dda74de3a541b1c4ae82f5f7b45 (diff)
downloadlwn-add703fda981b9719d37f371498b9f129acbd997.tar.gz
lwn-add703fda981b9719d37f371498b9f129acbd997.zip
blk-mq: use percpu_ref for mq usage count
Currently, blk-mq uses a percpu_counter to keep track of how many usages are in flight. The percpu_counter is drained while freezing to ensure that no usage is left in-flight after freezing is complete. blk_mq_queue_enter/exit() and blk_mq_[un]freeze_queue() implement this per-cpu gating mechanism. This type of code has relatively high chance of subtle bugs which are extremely difficult to trigger and it's way too hairy to be open coded in blk-mq. percpu_ref can serve the same purpose after the recent changes. This patch replaces the open-coded per-cpu usage counting and draining mechanism with percpu_ref. blk_mq_queue_enter() performs tryget_live on the ref and exit() performs put. blk_mq_freeze_queue() kills the ref and waits until the reference count reaches zero. blk_mq_unfreeze_queue() revives the ref and wakes up the waiters. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: Jens Axboe <axboe@kernel.dk> Cc: Nicholas A. Bellinger <nab@linux-iscsi.org> Cc: Kent Overstreet <kmo@daterainc.com> Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'Kbuild')
0 files changed, 0 insertions, 0 deletions