diff options
Diffstat (limited to 'drivers/nvme/host/rdma.c')
| -rw-r--r-- | drivers/nvme/host/rdma.c | 16 | 
1 files changed, 7 insertions, 9 deletions
| diff --git a/drivers/nvme/host/rdma.c b/drivers/nvme/host/rdma.c index cb4c3000a57e..dce59459ed41 100644 --- a/drivers/nvme/host/rdma.c +++ b/drivers/nvme/host/rdma.c @@ -1160,8 +1160,6 @@ static void nvme_rdma_unmap_data(struct nvme_rdma_queue *queue,  	}  	ib_dma_unmap_sg(ibdev, req->sg_table.sgl, req->nents, rq_dma_dir(rq)); - -	nvme_cleanup_cmd(rq);  	sg_free_table_chained(&req->sg_table, SG_CHUNK_SIZE);  } @@ -1501,8 +1499,8 @@ static void nvme_rdma_recv_done(struct ib_cq *cq, struct ib_wc *wc)  	 * aborts.  We don't even bother to allocate a struct request  	 * for them but rather special case them here.  	 */ -	if (unlikely(nvme_rdma_queue_idx(queue) == 0 && -			cqe->command_id >= NVME_AQ_BLK_MQ_DEPTH)) +	if (unlikely(nvme_is_aen_req(nvme_rdma_queue_idx(queue), +				     cqe->command_id)))  		nvme_complete_async_event(&queue->ctrl->ctrl, cqe->status,  				&cqe->result);  	else @@ -1768,7 +1766,6 @@ static blk_status_t nvme_rdma_queue_rq(struct blk_mq_hw_ctx *hctx,  	if (unlikely(err < 0)) {  		dev_err(queue->ctrl->ctrl.device,  			     "Failed to map data (%d)\n", err); -		nvme_cleanup_cmd(rq);  		goto err;  	} @@ -1779,18 +1776,19 @@ static blk_status_t nvme_rdma_queue_rq(struct blk_mq_hw_ctx *hctx,  	err = nvme_rdma_post_send(queue, sqe, req->sge, req->num_sge,  			req->mr ? &req->reg_wr.wr : NULL); -	if (unlikely(err)) { -		nvme_rdma_unmap_data(queue, rq); -		goto err; -	} +	if (unlikely(err)) +		goto err_unmap;  	return BLK_STS_OK; +err_unmap: +	nvme_rdma_unmap_data(queue, rq);  err:  	if (err == -ENOMEM || err == -EAGAIN)  		ret = BLK_STS_RESOURCE;  	else  		ret = BLK_STS_IOERR; +	nvme_cleanup_cmd(rq);  unmap_qe:  	ib_dma_unmap_single(dev, req->sqe.dma, sizeof(struct nvme_command),  			    DMA_TO_DEVICE); | 

