summaryrefslogtreecommitdiffstats
path: root/block/blk-core.c
diff options
context:
space:
mode:
authorJeff Moyer <jmoyer@redhat.com>2015-11-03 16:40:06 +0100
committerJens Axboe <axboe@fb.com>2015-11-03 16:42:19 +0100
commit2404e607a9ee36db361bebe32787dafa1f7d6c00 (patch)
tree38f0de79314cdf010e331897684f7097a28dbe51 /block/blk-core.c
parentblktrace: re-write setting q->blk_trace (diff)
downloadlinux-2404e607a9ee36db361bebe32787dafa1f7d6c00.tar.xz
linux-2404e607a9ee36db361bebe32787dafa1f7d6c00.zip
blk-mq: avoid excessive boot delays with large lun counts
Hi, Zhangqing Luo reported long boot times on a system with thousands of LUNs when scsi-mq was enabled. He narrowed the problem down to blk_mq_add_queue_tag_set, where every queue is frozen in order to set the BLK_MQ_F_TAG_SHARED flag. Each added device will freeze all queues added before it in sequence, which involves waiting for an RCU grace period for each one. We don't need to do this. After the second queue is added, only new queues need to be initialized with the shared tag. We can do that by percolating the flag up to the blk_mq_tag_set, and updating the newly added queue's hctxs if the flag is set. This problem was introduced by commit 0d2602ca30e41 (blk-mq: improve support for shared tags maps). Reported-and-tested-by: Jason Luo <zhangqing.luo@oracle.com> Reviewed-by: Ming Lei <ming.lei@canonical.com> Signed-off-by: Jeff Moyer <jmoyer@redhat.com> Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'block/blk-core.c')
0 files changed, 0 insertions, 0 deletions