]> git.baikalelectronics.ru Git - kernel.git/commit
scsi: lpfc: Fix pt2pt NVMe PRLI reject LOGO loop
authorJames Smart <jsmart2021@gmail.com>
Sat, 12 Feb 2022 16:31:20 +0000 (08:31 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Tue, 15 Feb 2022 03:07:51 +0000 (22:07 -0500)
commitb3dc916630c01d2c9142ed6f220090139b82c26f
tree678ebd7339453113510a6ed376a2e8750c50fff9
parent674dcf290a9fa1ac90d1862bb9ed5fb03bb9a1d0
scsi: lpfc: Fix pt2pt NVMe PRLI reject LOGO loop

When connected point to point, the driver does not know the FC4's supported
by the other end. In Fabrics, it can query the nameserver.  Thus the driver
must send PRLIs for the FC4s it supports and enable support based on the
acc(ept) or rej(ect) of the respective FC4 PRLI.  Currently the driver
supports SCSI and NVMe PRLIs.

Unfortunately, although the behavior is per standard, many devices have
come to expect only SCSI PRLIs. In this particular example, the NVMe PRLI
is properly RJT'd but the target decided that it must LOGO after seeing the
unexpected NVMe PRLI. The LOGO causes the sequence to restart and login is
now in an infinite failure loop.

Fix the problem by having the driver, on a pt2pt link, remember NVMe PRLI
accept or reject status across logout as long as the link stays "up".  When
retrying login, if the prior NVMe PRLI was rejected, it will not be sent on
the next login.

Link: https://lore.kernel.org/r/20220212163120.15385-1-jsmart2021@gmail.com
Cc: <stable@vger.kernel.org> # v5.4+
Reviewed-by: Ewan D. Milne <emilne@redhat.com>
Signed-off-by: James Smart <jsmart2021@gmail.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/lpfc/lpfc.h
drivers/scsi/lpfc/lpfc_attr.c
drivers/scsi/lpfc/lpfc_els.c
drivers/scsi/lpfc/lpfc_nportdisc.c