nvme-pci: fix freeing single sgl
authorKeith Busch <kbusch@kernel.org>
Fri, 10 Feb 2023 18:03:46 +0000 (10:03 -0800)
committerChristoph Hellwig <hch@lst.de>
Tue, 14 Feb 2023 05:40:52 +0000 (06:40 +0100)
There may only be a single DMA mapped entry from multiple physical
segments, which means we don't allocate a separte SGL list. Check the
number of allocations prior to know if we need to free something.

Freeing a single list allocation is the same for both PRP and SGL
usages, so we don't need to check the use_sgl flag anymore.

Fixes: 01df742d8c5c0 ("nvme-pci: remove SGL segment descriptors")
Reported-by: Niklas Schnelle <schnelle@linux.ibm.com>
Signed-off-by: Keith Busch <kbusch@kernel.org>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Tested-by: Niklas Schnelle <schnelle@linux.ibm.com>
drivers/nvme/host/pci.c

index a331fbf..47d6b00 100644 (file)
@@ -556,7 +556,7 @@ static void nvme_unmap_data(struct nvme_dev *dev, struct request *req)
        if (iod->nr_allocations == 0)
                dma_pool_free(dev->prp_small_pool, iod->list[0].sg_list,
                              iod->first_dma);
-       else if (iod->use_sgl)
+       else if (iod->nr_allocations == 1)
                dma_pool_free(dev->prp_page_pool, iod->list[0].sg_list,
                              iod->first_dma);
        else