Commit 0dfb992e authored by James Smart's avatar James Smart Committed by Jens Axboe

nvmet-fc: perform small cleanups on unneeded checks

While code reviewing saw a couple of items that can be cleaned up:
- In nvmet_fc_delete_target_queue(), the routine unlocks, then checks
  and relocks.  Reorganize to avoid the unlock/relock.
- In nvmet_fc_delete_target_queue(), there's a check on the disconnect
  state that is unnecessary as the routine validates the state before
  starting any action.
Signed-off-by: default avatarJames Smart <jsmart2021@gmail.com>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent a5c2b4f6
...@@ -677,7 +677,7 @@ nvmet_fc_delete_target_queue(struct nvmet_fc_tgt_queue *queue) ...@@ -677,7 +677,7 @@ nvmet_fc_delete_target_queue(struct nvmet_fc_tgt_queue *queue)
struct nvmet_fc_fcp_iod *fod = queue->fod; struct nvmet_fc_fcp_iod *fod = queue->fod;
struct nvmet_fc_defer_fcp_req *deferfcp, *tempptr; struct nvmet_fc_defer_fcp_req *deferfcp, *tempptr;
unsigned long flags; unsigned long flags;
int i, writedataactive; int i;
bool disconnect; bool disconnect;
disconnect = atomic_xchg(&queue->connected, 0); disconnect = atomic_xchg(&queue->connected, 0);
...@@ -688,20 +688,18 @@ nvmet_fc_delete_target_queue(struct nvmet_fc_tgt_queue *queue) ...@@ -688,20 +688,18 @@ nvmet_fc_delete_target_queue(struct nvmet_fc_tgt_queue *queue)
if (fod->active) { if (fod->active) {
spin_lock(&fod->flock); spin_lock(&fod->flock);
fod->abort = true; fod->abort = true;
writedataactive = fod->writedataactive;
spin_unlock(&fod->flock);
/* /*
* only call lldd abort routine if waiting for * only call lldd abort routine if waiting for
* writedata. other outstanding ops should finish * writedata. other outstanding ops should finish
* on their own. * on their own.
*/ */
if (writedataactive) { if (fod->writedataactive) {
spin_lock(&fod->flock);
fod->aborted = true; fod->aborted = true;
spin_unlock(&fod->flock); spin_unlock(&fod->flock);
tgtport->ops->fcp_abort( tgtport->ops->fcp_abort(
&tgtport->fc_target_port, fod->fcpreq); &tgtport->fc_target_port, fod->fcpreq);
} } else
spin_unlock(&fod->flock);
} }
} }
...@@ -741,8 +739,7 @@ nvmet_fc_delete_target_queue(struct nvmet_fc_tgt_queue *queue) ...@@ -741,8 +739,7 @@ nvmet_fc_delete_target_queue(struct nvmet_fc_tgt_queue *queue)
flush_workqueue(queue->work_q); flush_workqueue(queue->work_q);
if (disconnect) nvmet_sq_destroy(&queue->nvme_sq);
nvmet_sq_destroy(&queue->nvme_sq);
nvmet_fc_tgt_q_put(queue); nvmet_fc_tgt_q_put(queue);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment