diff options
author | Dan Carpenter <dan.carpenter@oracle.com> | 2016-07-15 14:18:57 +0300 |
---|---|---|
committer | Martin K. Petersen <martin.petersen@oracle.com> | 2016-07-15 15:13:52 -0400 |
commit | 0073887ae5e23bfadb76fc5951b1fcd508a7a3bd (patch) | |
tree | 527d9d3cc6611c0931af9a19da3b4dbca599048c | |
parent | 866d372e86aa256f3645b035c68350b08e182b9b (diff) | |
download | linux-0073887ae5e23bfadb76fc5951b1fcd508a7a3bd.tar.gz linux-0073887ae5e23bfadb76fc5951b1fcd508a7a3bd.tar.bz2 linux-0073887ae5e23bfadb76fc5951b1fcd508a7a3bd.zip |
ibmvfc: prevent a potential deadlock
My static checker complains that we need to unlock on this path. Seems
true.
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: Brian King <brking@linux.vnet.ibm.com>
Reviewed-by: Ewan D. Milne <emilne@redhat.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r-- | drivers/scsi/ibmvscsi/ibmvfc.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/scsi/ibmvscsi/ibmvfc.c b/drivers/scsi/ibmvscsi/ibmvfc.c index fc523c3e5019..ab67ec4b6bd6 100644 --- a/drivers/scsi/ibmvscsi/ibmvfc.c +++ b/drivers/scsi/ibmvscsi/ibmvfc.c @@ -4722,6 +4722,8 @@ static void ibmvfc_rport_add_thread(struct work_struct *work) tgt_dbg(tgt, "Setting rport roles\n"); fc_remote_port_rolechg(rport, tgt->ids.roles); put_device(&rport->dev); + } else { + spin_unlock_irqrestore(vhost->host->host_lock, flags); } kref_put(&tgt->kref, ibmvfc_release_tgt); |