diff mbox series

blk-mq: skip zero-queue maps in blk_mq_map_swqueue

Message ID 20181217172856.14743-1-ming.lei@redhat.com (mailing list archive)
State New, archived
Headers show
Series blk-mq: skip zero-queue maps in blk_mq_map_swqueue | expand

Commit Message

Ming Lei Dec. 17, 2018, 5:28 p.m. UTC
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>
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Ming Lei <ming.lei@redhat.com>
---
 block/blk-mq.c | 3 +++
 1 file changed, 3 insertions(+)

Comments

Christoph Hellwig Dec. 17, 2018, 5:30 p.m. UTC | #1
On Tue, Dec 18, 2018 at 01:28:56AM +0800, Ming Lei wrote:
> >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().

Looks fine,

Reviewed-by: Christoph Hellwig <hch@lst.de>
Jens Axboe Dec. 17, 2018, 5:32 p.m. UTC | #2
On 12/17/18 10:28 AM, Ming Lei wrote:
> 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().

Applied, thanks.
diff mbox series

Patch

diff --git a/block/blk-mq.c b/block/blk-mq.c
index 17de117be019..8075b16c5228 100644
--- a/block/blk-mq.c
+++ b/block/blk-mq.c
@@ -2433,6 +2433,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);
 
 			/*