mirror of
https://github.com/nxp-imx/linux-imx.git
synced 2025-07-13 20:59:37 +02:00
scsi: lpfc: Move NPIV's transport unregistration to after resource clean up
[ Upstream commit 4ddf01f2f1
]
There are cases after NPIV deletion where the fabric switch still believes
the NPIV is logged into the fabric. This occurs when a vport is
unregistered before the Remove All DA_ID CT and LOGO ELS are sent to the
fabric.
Currently fc_remove_host(), which calls dev_loss_tmo for all D_IDs including
the fabric D_ID, removes the last ndlp reference and frees the ndlp rport
object. This sometimes causes the race condition where the final DA_ID and
LOGO are skipped from being sent to the fabric switch.
Fix by moving the fc_remove_host() and scsi_remove_host() calls after DA_ID
and LOGO are sent.
Signed-off-by: Justin Tee <justin.tee@broadcom.com>
Link: https://lore.kernel.org/r/20240305200503.57317-3-justintee8345@gmail.com
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
ff54c87f32
commit
76337eb8da
|
@ -683,10 +683,6 @@ lpfc_vport_delete(struct fc_vport *fc_vport)
|
|||
lpfc_free_sysfs_attr(vport);
|
||||
lpfc_debugfs_terminate(vport);
|
||||
|
||||
/* Remove FC host to break driver binding. */
|
||||
fc_remove_host(shost);
|
||||
scsi_remove_host(shost);
|
||||
|
||||
/* Send the DA_ID and Fabric LOGO to cleanup Nameserver entries. */
|
||||
ndlp = lpfc_findnode_did(vport, Fabric_DID);
|
||||
if (!ndlp)
|
||||
|
@ -730,6 +726,10 @@ lpfc_vport_delete(struct fc_vport *fc_vport)
|
|||
|
||||
skip_logo:
|
||||
|
||||
/* Remove FC host to break driver binding. */
|
||||
fc_remove_host(shost);
|
||||
scsi_remove_host(shost);
|
||||
|
||||
lpfc_cleanup(vport);
|
||||
|
||||
/* Remove scsi host now. The nodes are cleaned up. */
|
||||
|
|
Loading…
Reference in New Issue
Block a user