aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteve Wise <swise@opengridcomputing.com>2016-09-01 12:12:25 -0400
committerSagi Grimberg <sagi@grimberg.me>2016-09-04 03:00:53 -0400
commitcdbecc8d24b642b67ae79a0acc2ff18d3d0e677e (patch)
tree00ff4a84a7f5dd39dee42fc589aefbee12abb77d
parent37eb816c0867b1b0db273d22b530780a0a083980 (diff)
nvme_rdma: keep a ref on the ctrl during delete/flush
Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Sagi Grimberg <sagi@grimbrg.me> Signed-off-by: Steve Wise <swise@opengridcomputing.com> Signed-off-by: Sagi Grimberg <sagi@grimberg.me>
-rw-r--r--drivers/nvme/host/rdma.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/drivers/nvme/host/rdma.c b/drivers/nvme/host/rdma.c
index ab545fb347a0..15b0c1d025f5 100644
--- a/drivers/nvme/host/rdma.c
+++ b/drivers/nvme/host/rdma.c
@@ -1351,9 +1351,15 @@ static int nvme_rdma_device_unplug(struct nvme_rdma_queue *queue)
1351 ret = 1; 1351 ret = 1;
1352 } 1352 }
1353 1353
1354 /* Queue controller deletion */ 1354 /*
1355 * Queue controller deletion. Keep a reference until all
1356 * work is flushed since delete_work will free the ctrl mem
1357 */
1358 kref_get(&ctrl->ctrl.kref);
1355 queue_work(nvme_rdma_wq, &ctrl->delete_work); 1359 queue_work(nvme_rdma_wq, &ctrl->delete_work);
1356 flush_work(&ctrl->delete_work); 1360 flush_work(&ctrl->delete_work);
1361 nvme_put_ctrl(&ctrl->ctrl);
1362
1357 return ret; 1363 return ret;
1358} 1364}
1359 1365
@@ -1700,15 +1706,19 @@ static int __nvme_rdma_del_ctrl(struct nvme_rdma_ctrl *ctrl)
1700static int nvme_rdma_del_ctrl(struct nvme_ctrl *nctrl) 1706static int nvme_rdma_del_ctrl(struct nvme_ctrl *nctrl)
1701{ 1707{
1702 struct nvme_rdma_ctrl *ctrl = to_rdma_ctrl(nctrl); 1708 struct nvme_rdma_ctrl *ctrl = to_rdma_ctrl(nctrl);
1703 int ret; 1709 int ret = 0;
1704 1710
1711 /*
1712 * Keep a reference until all work is flushed since
1713 * __nvme_rdma_del_ctrl can free the ctrl mem
1714 */
1715 if (!kref_get_unless_zero(&ctrl->ctrl.kref))
1716 return -EBUSY;
1705 ret = __nvme_rdma_del_ctrl(ctrl); 1717 ret = __nvme_rdma_del_ctrl(ctrl);
1706 if (ret) 1718 if (!ret)
1707 return ret; 1719 flush_work(&ctrl->delete_work);
1708 1720 nvme_put_ctrl(&ctrl->ctrl);
1709 flush_work(&ctrl->delete_work); 1721 return ret;
1710
1711 return 0;
1712} 1722}
1713 1723
1714static void nvme_rdma_remove_ctrl_work(struct work_struct *work) 1724static void nvme_rdma_remove_ctrl_work(struct work_struct *work)