mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-19 19:14:01 +08:00
nvme: add missing unmaps in nvme_queue_rq
When we fail various metadata related operations in nvme_queue_rq we need to unmap the data SGL. Cc: stable@vger.kernel.org Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Keith Busch <keith.busch@intel.com> Signed-off-by: Jens Axboe <axboe@fb.com>
This commit is contained in:
parent
c5c9f25b98
commit
bf508e910b
@ -896,19 +896,28 @@ static int nvme_queue_rq(struct blk_mq_hw_ctx *hctx,
|
|||||||
goto retry_cmd;
|
goto retry_cmd;
|
||||||
}
|
}
|
||||||
if (blk_integrity_rq(req)) {
|
if (blk_integrity_rq(req)) {
|
||||||
if (blk_rq_count_integrity_sg(req->q, req->bio) != 1)
|
if (blk_rq_count_integrity_sg(req->q, req->bio) != 1) {
|
||||||
|
dma_unmap_sg(dev->dev, iod->sg, iod->nents,
|
||||||
|
dma_dir);
|
||||||
goto error_cmd;
|
goto error_cmd;
|
||||||
|
}
|
||||||
|
|
||||||
sg_init_table(iod->meta_sg, 1);
|
sg_init_table(iod->meta_sg, 1);
|
||||||
if (blk_rq_map_integrity_sg(
|
if (blk_rq_map_integrity_sg(
|
||||||
req->q, req->bio, iod->meta_sg) != 1)
|
req->q, req->bio, iod->meta_sg) != 1) {
|
||||||
|
dma_unmap_sg(dev->dev, iod->sg, iod->nents,
|
||||||
|
dma_dir);
|
||||||
goto error_cmd;
|
goto error_cmd;
|
||||||
|
}
|
||||||
|
|
||||||
if (rq_data_dir(req))
|
if (rq_data_dir(req))
|
||||||
nvme_dif_remap(req, nvme_dif_prep);
|
nvme_dif_remap(req, nvme_dif_prep);
|
||||||
|
|
||||||
if (!dma_map_sg(nvmeq->q_dmadev, iod->meta_sg, 1, dma_dir))
|
if (!dma_map_sg(nvmeq->q_dmadev, iod->meta_sg, 1, dma_dir)) {
|
||||||
|
dma_unmap_sg(dev->dev, iod->sg, iod->nents,
|
||||||
|
dma_dir);
|
||||||
goto error_cmd;
|
goto error_cmd;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user