summaryrefslogtreecommitdiff
path: root/samples
diff options
context:
space:
mode:
authorJames Smart <jsmart2021@gmail.com>2021-05-14 22:55:53 +0300
committerMartin K. Petersen <martin.petersen@oracle.com>2021-05-22 06:23:27 +0300
commit4012baeab6ca22b7f7beb121b6d0da0a62942fdd (patch)
treea2dc80b2384b248f25a14cb6835a7cf7fab6c292 /samples
parent1037e4b4f81dc4ddf928e0ca2f1b182efdfdcc9d (diff)
downloadlinux-4012baeab6ca22b7f7beb121b6d0da0a62942fdd.tar.xz
scsi: lpfc: Fix Node recovery when driver is handling simultaneous PLOGIs
When lpfc is handling a solicited and unsolicited PLOGI with another initiator, the remote initiator is never recovered. The node for the initiator is erroneouosly removed and all resources released. In lpfc_cmpl_els_plogi(), when lpfc_els_retry() returns a failure code, the driver is calling the state machine with a device remove event because the remote port is not currently registered with the SCSI or NVMe transports. The issue is that on a PLOGI "collision" the driver correctly aborts the solicited PLOGI and allows the unsolicited PLOGI to complete the process, but this process is interrupted with a device_rm event. Introduce logic in the PLOGI completion to capture the PLOGI collision event and jump out of the routine. This will avoid removal of the node. If there is no collision, the normal node removal will occur. Fixes: 52edb2caf675 ("scsi: lpfc: Remove ndlp when a PLOGI/ADISC/PRLI/REG_RPI ultimately fails") Cc: <stable@vger.kernel.org> # v5.11+ Link: https://lore.kernel.org/r/20210514195559.119853-6-jsmart2021@gmail.com Co-developed-by: Justin Tee <justin.tee@broadcom.com> Signed-off-by: Justin Tee <justin.tee@broadcom.com> Signed-off-by: James Smart <jsmart2021@gmail.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'samples')
0 files changed, 0 insertions, 0 deletions