nvme-pci: don't create a read hctx mapping without read queues
authorAlan Mikhak <alan.mikhak@sifive.com>
Mon, 8 Jul 2019 17:24:12 +0000 (10:24 -0700)
committerChristoph Hellwig <hch@lst.de>
Tue, 9 Jul 2019 20:44:44 +0000 (13:44 -0700)
Only request an IRQ mapping for read queues if at least one read queue
is being allocted, as nvme_pci_map_queues() will later on ignore the
unnecessary mapping request should nvme_dev_add() request such an IRQ
mapping even though no read queues are being allocated.  However,
nvme_dev_add() can avoid making the request by checking the number of
read queues without assuming. This would bring it more in line with
nvme_setup_irqs() and nvme_calc_irq_sets().

Signed-off-by: Alan Mikhak <alan.mikhak@sifive.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
drivers/nvme/host/pci.c

index 49c1fc9907a641f4db305e142d8706c89f3b5cbc..0423ddd97f4b5a42a3d0d8b49d1a1b2c1c702cf0 100644 (file)
@@ -2250,7 +2250,9 @@ static int nvme_dev_add(struct nvme_dev *dev)
        if (!dev->ctrl.tagset) {
                dev->tagset.ops = &nvme_mq_ops;
                dev->tagset.nr_hw_queues = dev->online_queues - 1;
-               dev->tagset.nr_maps = 2; /* default + read */
+               dev->tagset.nr_maps = 1; /* default */
+               if (dev->io_queues[HCTX_TYPE_READ])
+                       dev->tagset.nr_maps++;
                if (dev->io_queues[HCTX_TYPE_POLL])
                        dev->tagset.nr_maps++;
                dev->tagset.timeout = NVME_IO_TIMEOUT;