aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDaniel Wagner <wagi@kernel.org>2025-04-08 17:29:10 +0200
committerChristoph Hellwig <hch@lst.de>2025-04-09 13:03:56 +0200
commit70289ae5cac4d3a39575405aaf63330486cea030 (patch)
tree9aa26f10c6cb13730e969b29bea317fea13a63fa
parentnvmet-fc: take tgtport reference only once (diff)
downloadwireguard-linux-70289ae5cac4d3a39575405aaf63330486cea030.tar.xz
wireguard-linux-70289ae5cac4d3a39575405aaf63330486cea030.zip
nvmet-fc: put ref when assoc->del_work is already scheduled
Do not leak the tgtport reference when the work is already scheduled. Signed-off-by: Daniel Wagner <wagi@kernel.org> Reviewed-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Christoph Hellwig <hch@lst.de>
-rw-r--r--drivers/nvme/target/fc.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/nvme/target/fc.c b/drivers/nvme/target/fc.c
index 61e9eea3bee4..7b50130f10f6 100644
--- a/drivers/nvme/target/fc.c
+++ b/drivers/nvme/target/fc.c
@@ -1073,7 +1073,8 @@ static void
nvmet_fc_schedule_delete_assoc(struct nvmet_fc_tgt_assoc *assoc)
{
nvmet_fc_tgtport_get(assoc->tgtport);
- queue_work(nvmet_wq, &assoc->del_work);
+ if (!queue_work(nvmet_wq, &assoc->del_work))
+ nvmet_fc_tgtport_put(assoc->tgtport);
}
static bool