diff options
author | 2025-04-08 17:29:10 +0200 | |
---|---|---|
committer | 2025-04-09 13:03:56 +0200 | |
commit | 70289ae5cac4d3a39575405aaf63330486cea030 (patch) | |
tree | 9aa26f10c6cb13730e969b29bea317fea13a63fa | |
parent | nvmet-fc: take tgtport reference only once (diff) | |
download | wireguard-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.c | 3 |
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 |