Commit cdbecc8d authored by Steve Wise's avatar Steve Wise Committed by Sagi Grimberg

nvme_rdma: keep a ref on the ctrl during delete/flush

Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarSagi Grimberg <sagi@grimbrg.me>
Signed-off-by: default avatarSteve Wise <swise@opengridcomputing.com>
Signed-off-by: default avatarSagi Grimberg <sagi@grimberg.me>
parent 37eb816c
...@@ -1351,9 +1351,15 @@ static int nvme_rdma_device_unplug(struct nvme_rdma_queue *queue) ...@@ -1351,9 +1351,15 @@ static int nvme_rdma_device_unplug(struct nvme_rdma_queue *queue)
ret = 1; ret = 1;
} }
/* Queue controller deletion */ /*
* Queue controller deletion. Keep a reference until all
* work is flushed since delete_work will free the ctrl mem
*/
kref_get(&ctrl->ctrl.kref);
queue_work(nvme_rdma_wq, &ctrl->delete_work); queue_work(nvme_rdma_wq, &ctrl->delete_work);
flush_work(&ctrl->delete_work); flush_work(&ctrl->delete_work);
nvme_put_ctrl(&ctrl->ctrl);
return ret; return ret;
} }
...@@ -1700,15 +1706,19 @@ static int __nvme_rdma_del_ctrl(struct nvme_rdma_ctrl *ctrl) ...@@ -1700,15 +1706,19 @@ static int __nvme_rdma_del_ctrl(struct nvme_rdma_ctrl *ctrl)
static int nvme_rdma_del_ctrl(struct nvme_ctrl *nctrl) static int nvme_rdma_del_ctrl(struct nvme_ctrl *nctrl)
{ {
struct nvme_rdma_ctrl *ctrl = to_rdma_ctrl(nctrl); struct nvme_rdma_ctrl *ctrl = to_rdma_ctrl(nctrl);
int ret; int ret = 0;
/*
* Keep a reference until all work is flushed since
* __nvme_rdma_del_ctrl can free the ctrl mem
*/
if (!kref_get_unless_zero(&ctrl->ctrl.kref))
return -EBUSY;
ret = __nvme_rdma_del_ctrl(ctrl); ret = __nvme_rdma_del_ctrl(ctrl);
if (ret) if (!ret)
return ret; flush_work(&ctrl->delete_work);
nvme_put_ctrl(&ctrl->ctrl);
flush_work(&ctrl->delete_work); return ret;
return 0;
} }
static void nvme_rdma_remove_ctrl_work(struct work_struct *work) static void nvme_rdma_remove_ctrl_work(struct work_struct *work)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment