blk-mq: skip zero-queue maps in blk_mq_map_swqueue
authorMing Lei <ming.lei@redhat.com>
Mon, 17 Dec 2018 17:28:56 +0000 (01:28 +0800)
committerJens Axboe <axboe@kernel.dk>
Mon, 17 Dec 2018 18:19:55 +0000 (11:19 -0700)
From 7e849dd9cf37 ("nvme-pci: don't share queue maps"), the mapping
table won't be initialized actually if map->nr_queues is zero, so
we can't use blk_mq_map_queue_type() to retrieve hctx any more.

This way still may cause broken mapping, fix it by skipping zero-queues
maps in blk_mq_map_swqueue().

Cc: Jeff Moyer <jmoyer@redhat.com>
Cc: Mike Snitzer <snitzer@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Ming Lei <ming.lei@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
block/blk-mq.c

index 9c1c1544bac31623665e0055d0e3db21ed987a44..6847f014606b1a3996d8acee1a8b141ecb598045 100644 (file)
@@ -2438,6 +2438,9 @@ static void blk_mq_map_swqueue(struct request_queue *q)
 
                ctx = per_cpu_ptr(q->queue_ctx, i);
                for (j = 0; j < set->nr_maps; j++) {
+                       if (!set->map[j].nr_queues)
+                               continue;
+
                        hctx = blk_mq_map_queue_type(q, j, i);
 
                        /*