]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
scsi: qla2xxx: Fix N2N inconsistent PLOGI
authorQuinn Tran <qutran@marvell.com>
Thu, 10 Mar 2022 09:25:57 +0000 (01:25 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 8 Apr 2022 12:06:46 +0000 (14:06 +0200)
commit c13ce47c64ea8f14e77eecb40d1e7c2ac667f898 upstream.

For N2N topology, ELS Passthrough is used to send PLOGI. On failure of ELS
pass through PLOGI, driver flipped over to using LLIOCB PLOGI for N2N. This
is not consistent. Delete the session to restart the connection where ELS
pass through PLOGI would be used consistently.

Link: https://lore.kernel.org/r/20220310092604.22950-7-njavali@marvell.com
Fixes: c76ae845ea83 ("scsi: qla2xxx: Add error handling for PLOGI ELS passthrough")
Cc: stable@vger.kernel.org
Reviewed-by: Himanshu Madhani <himanshu.madhani@oracle.com>
Signed-off-by: Quinn Tran <qutran@marvell.com>
Signed-off-by: Nilesh Javali <njavali@marvell.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/scsi/qla2xxx/qla_iocb.c

index 7dd82214d59f637b2b489ef28a96f0e336dd05cf..85cccc7b9f83089d84b50c415c0f4aac1aaee0a5 100644 (file)
@@ -2943,6 +2943,7 @@ static void qla2x00_els_dcmd2_sp_done(srb_t *sp, int res)
                                        set_bit(ISP_ABORT_NEEDED,
                                            &vha->dpc_flags);
                                        qla2xxx_wake_dpc(vha);
+                                       break;
                                }
                                fallthrough;
                        default:
@@ -2952,9 +2953,7 @@ static void qla2x00_els_dcmd2_sp_done(srb_t *sp, int res)
                                    fw_status[0], fw_status[1], fw_status[2]);
 
                                fcport->flags &= ~FCF_ASYNC_SENT;
-                               qla2x00_set_fcport_disc_state(fcport,
-                                   DSC_LOGIN_FAILED);
-                               set_bit(RELOGIN_NEEDED, &vha->dpc_flags);
+                               qlt_schedule_sess_for_deletion(fcport);
                                break;
                        }
                        break;
@@ -2966,8 +2965,7 @@ static void qla2x00_els_dcmd2_sp_done(srb_t *sp, int res)
                            fw_status[0], fw_status[1], fw_status[2]);
 
                        sp->fcport->flags &= ~FCF_ASYNC_SENT;
-                       qla2x00_set_fcport_disc_state(fcport, DSC_LOGIN_FAILED);
-                       set_bit(RELOGIN_NEEDED, &vha->dpc_flags);
+                       qlt_schedule_sess_for_deletion(fcport);
                        break;
                }