summary refs log tree commit diff
path: root/drivers/nvme/target
diff options
context:
space:
mode:
authorAmit Engel <Amit.Engel@dell.com>2023-01-23 14:37:28 +0200
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2023-02-22 12:59:44 +0100
commitfd646ac5403f9a6d693065edeb21fec2a8b19727 (patch)
treeafb186c52e2bc881a92a8233c5e96b0fc0b2f387 /drivers/nvme/target
parentf1eb22d0ff064ad458b3b1a1eaa84ac3996206c2 (diff)
downloadlinux-fd646ac5403f9a6d693065edeb21fec2a8b19727.tar.gz
nvme-fc: fix a missing queue put in nvmet_fc_ls_create_association
[ Upstream commit 0cab4404874f2de52617de8400c844891c6ea1ce ]

As part of nvmet_fc_ls_create_association there is a case where
nvmet_fc_alloc_target_queue fails right after a new association with an
admin queue is created. In this case, no one releases the get taken in
nvmet_fc_alloc_target_assoc.  This fix is adding the missing put.

Signed-off-by: Amit Engel <Amit.Engel@dell.com>
Reviewed-by: James Smart <jsmart2021@gmail.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'drivers/nvme/target')
-rw-r--r--drivers/nvme/target/fc.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/nvme/target/fc.c b/drivers/nvme/target/fc.c
index ab2627e17bb9..1ab6601fdd5c 100644
--- a/drivers/nvme/target/fc.c
+++ b/drivers/nvme/target/fc.c
@@ -1685,8 +1685,10 @@ nvmet_fc_ls_create_association(struct nvmet_fc_tgtport *tgtport,
 		else {
 			queue = nvmet_fc_alloc_target_queue(iod->assoc, 0,
 					be16_to_cpu(rqst->assoc_cmd.sqsize));
-			if (!queue)
+			if (!queue) {
 				ret = VERR_QUEUE_ALLOC_FAIL;
+				nvmet_fc_tgt_a_put(iod->assoc);
+			}
 		}
 	}