nvme-rdma: fix double freeing of async event data
Some error paths in configuration of admin queue free data buffer associated with async request SQE without resetting the data buffer pointer to NULL, This buffer is also freed up again if the controller is shutdown or reset. Signed-off-by: Prabhath Sajeepa <psajeepa@purestorage.com> Reviewed-by: Roland Dreier <roland@purestorage.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
This commit is contained in:
parent
f6c8e432cb
commit
6344d02dc8
|
@ -184,6 +184,7 @@ static int nvme_rdma_alloc_qe(struct ib_device *ibdev, struct nvme_rdma_qe *qe,
|
||||||
qe->dma = ib_dma_map_single(ibdev, qe->data, capsule_size, dir);
|
qe->dma = ib_dma_map_single(ibdev, qe->data, capsule_size, dir);
|
||||||
if (ib_dma_mapping_error(ibdev, qe->dma)) {
|
if (ib_dma_mapping_error(ibdev, qe->dma)) {
|
||||||
kfree(qe->data);
|
kfree(qe->data);
|
||||||
|
qe->data = NULL;
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -823,6 +824,7 @@ static int nvme_rdma_configure_admin_queue(struct nvme_rdma_ctrl *ctrl,
|
||||||
out_free_async_qe:
|
out_free_async_qe:
|
||||||
nvme_rdma_free_qe(ctrl->device->dev, &ctrl->async_event_sqe,
|
nvme_rdma_free_qe(ctrl->device->dev, &ctrl->async_event_sqe,
|
||||||
sizeof(struct nvme_command), DMA_TO_DEVICE);
|
sizeof(struct nvme_command), DMA_TO_DEVICE);
|
||||||
|
ctrl->async_event_sqe.data = NULL;
|
||||||
out_free_queue:
|
out_free_queue:
|
||||||
nvme_rdma_free_queue(&ctrl->queues[0]);
|
nvme_rdma_free_queue(&ctrl->queues[0]);
|
||||||
return error;
|
return error;
|
||||||
|
|
Loading…
Reference in New Issue