diff options
author | Steve Wise <swise@opengridcomputing.com> | 2016-09-01 12:12:25 -0400 |
---|---|---|
committer | Sagi Grimberg <sagi@grimberg.me> | 2016-09-04 03:00:53 -0400 |
commit | cdbecc8d24b642b67ae79a0acc2ff18d3d0e677e (patch) | |
tree | 00ff4a84a7f5dd39dee42fc589aefbee12abb77d | |
parent | 37eb816c0867b1b0db273d22b530780a0a083980 (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.c | 26 |
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) | |||
1700 | static int nvme_rdma_del_ctrl(struct nvme_ctrl *nctrl) | 1706 | static 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 | ||
1714 | static void nvme_rdma_remove_ctrl_work(struct work_struct *work) | 1724 | static void nvme_rdma_remove_ctrl_work(struct work_struct *work) |