From 6b0d7b82c91cf7e6201e9f76cbf553470e106439 Mon Sep 17 00:00:00 2001 From: wuzhouhui Date: Fri, 15 Feb 2019 09:36:48 +0800 Subject: [PATCH] ocssd: hold lock when calling nvme_ctrlr_submit_admin_request nvme_ctrlr_submit_admin_request() will access admin queue, and we should hold ctrl->ctrlr_lock when access it. Change-Id: Iff576fe5e14e854eb38dbc64d6c6d9ec1ba17056 Signed-off-by: wuzhouhui Reviewed-on: https://review.gerrithub.io/c/444793 Tested-by: SPDK CI Jenkins Reviewed-by: Ben Walker Reviewed-by: Jim Harris --- lib/nvme/nvme_ctrlr_ocssd_cmd.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lib/nvme/nvme_ctrlr_ocssd_cmd.c b/lib/nvme/nvme_ctrlr_ocssd_cmd.c index 650e690569..2eba219cec 100644 --- a/lib/nvme/nvme_ctrlr_ocssd_cmd.c +++ b/lib/nvme/nvme_ctrlr_ocssd_cmd.c @@ -63,6 +63,7 @@ spdk_nvme_ocssd_ctrlr_cmd_geometry(struct spdk_nvme_ctrlr *ctrlr, uint32_t nsid, { struct nvme_request *req; struct spdk_nvme_cmd *cmd; + int rc; if (!payload || (payload_size != sizeof(struct spdk_ocssd_geometry_data))) { return -EINVAL; @@ -79,7 +80,9 @@ spdk_nvme_ocssd_ctrlr_cmd_geometry(struct spdk_nvme_ctrlr *ctrlr, uint32_t nsid, cmd = &req->cmd; cmd->opc = SPDK_OCSSD_OPC_GEOMETRY; cmd->nsid = nsid; - nvme_robust_mutex_unlock(&ctrlr->ctrlr_lock); - return nvme_ctrlr_submit_admin_request(ctrlr, req); + rc = nvme_ctrlr_submit_admin_request(ctrlr, req); + + nvme_robust_mutex_unlock(&ctrlr->ctrlr_lock); + return rc; }