Blame SOURCES/0149-scsi-scsi-qla2xxx-Fix-device-connect-issues-in-P2P-c.patch

3d7c23
From b338d44a8648a0e015780d73fc806dedbc78b59f Mon Sep 17 00:00:00 2001
3d7c23
From: Himanshu Madhani <hmadhani@redhat.com>
3d7c23
Date: Thu, 21 Nov 2019 16:36:59 -0500
3d7c23
Subject: [PATCH 149/155] [scsi] scsi: qla2xxx: Fix device connect issues in
3d7c23
 P2P configuration
3d7c23
3d7c23
Message-id: <20191121163701.43688-25-hmadhani@redhat.com>
3d7c23
Patchwork-id: 287856
3d7c23
O-Subject: [RHLE 7.8 e-stor PATCH v3 24/26] scsi: qla2xxx: Fix device connect issues in P2P configuration
3d7c23
Bugzilla: 1731581
3d7c23
RH-Acked-by: Jarod Wilson <jarod@redhat.com>
3d7c23
RH-Acked-by: Ewan Milne <emilne@redhat.com>
3d7c23
RH-Acked-by: Tony Camuso <tcamuso@redhat.com>
3d7c23
3d7c23
From: Arun Easi <aeasi@marvell.com>
3d7c23
3d7c23
Bugzilla 1731581
3d7c23
3d7c23
P2P needs to take the alternate plogi route.
3d7c23
3d7c23
Link: https://lore.kernel.org/r/20191105150657.8092-8-hmadhani@marvell.com
3d7c23
Reviewed-by: Ewan D. Milne <emilne@redhat.com>
3d7c23
Signed-off-by: Arun Easi <aeasi@marvell.com>
3d7c23
Signed-off-by: Himanshu Madhani <hmadhani@marvell.com>
3d7c23
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
3d7c23
(cherry picked from commit 65e9200938052ce90f24421bb057e1be1d6147c7)
3d7c23
Signed-off-by: Himanshu Madhani <hmadhani@redhat.com>
3d7c23
Signed-off-by: Jan Stancek <jstancek@redhat.com>
3d7c23
---
3d7c23
 drivers/scsi/qla2xxx/qla_gbl.h  | 1 +
3d7c23
 drivers/scsi/qla2xxx/qla_init.c | 9 +++++++++
3d7c23
 drivers/scsi/qla2xxx/qla_iocb.c | 5 ++---
3d7c23
 3 files changed, 12 insertions(+), 3 deletions(-)
3d7c23
3d7c23
diff --git a/drivers/scsi/qla2xxx/qla_gbl.h b/drivers/scsi/qla2xxx/qla_gbl.h
3d7c23
index 6d46518f4e9a..69faea46da73 100644
3d7c23
--- a/drivers/scsi/qla2xxx/qla_gbl.h
3d7c23
+++ b/drivers/scsi/qla2xxx/qla_gbl.h
3d7c23
@@ -912,4 +912,5 @@ int qla2x00_set_data_rate(scsi_qla_host_t *vha, uint16_t mode);
3d7c23
 
3d7c23
 /* nvme.c */
3d7c23
 void qla_nvme_unregister_remote_port(struct fc_port *fcport);
3d7c23
+void qla_handle_els_plogi_done(scsi_qla_host_t *vha, struct event_arg *ea);
3d7c23
 #endif /* _QLA_GBL_H */
3d7c23
diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c
3d7c23
index 3344f149e1c2..c327139a9ced 100644
3d7c23
--- a/drivers/scsi/qla2xxx/qla_init.c
3d7c23
+++ b/drivers/scsi/qla2xxx/qla_init.c
3d7c23
@@ -1732,6 +1732,15 @@ void qla24xx_handle_relogin_event(scsi_qla_host_t *vha,
3d7c23
 	qla24xx_fcport_handle_login(vha, fcport);
3d7c23
 }
3d7c23
 
3d7c23
+void qla_handle_els_plogi_done(scsi_qla_host_t *vha,
3d7c23
+				      struct event_arg *ea)
3d7c23
+{
3d7c23
+	ql_dbg(ql_dbg_disc, vha, 0x2118,
3d7c23
+	    "%s %d %8phC post PRLI\n",
3d7c23
+	    __func__, __LINE__, ea->fcport->port_name);
3d7c23
+	qla24xx_post_prli_work(vha, ea->fcport);
3d7c23
+}
3d7c23
+
3d7c23
 /*
3d7c23
  * RSCN(s) came in for this fcport, but the RSCN(s) was not able
3d7c23
  * to be consumed by the fcport
3d7c23
diff --git a/drivers/scsi/qla2xxx/qla_iocb.c b/drivers/scsi/qla2xxx/qla_iocb.c
3d7c23
index 918b18d53599..337fcd555ae5 100644
3d7c23
--- a/drivers/scsi/qla2xxx/qla_iocb.c
3d7c23
+++ b/drivers/scsi/qla2xxx/qla_iocb.c
3d7c23
@@ -2868,9 +2868,8 @@ qla2x00_els_dcmd2_sp_done(void *ptr, int res)
3d7c23
 		case CS_COMPLETE:
3d7c23
 			memset(&ea, 0, sizeof(ea));
3d7c23
 			ea.fcport = fcport;
3d7c23
-			ea.data[0] = MBS_COMMAND_COMPLETE;
3d7c23
-			ea.sp = sp;
3d7c23
-			qla24xx_handle_plogi_done_event(vha, &ea);
3d7c23
+			ea.rc = res;
3d7c23
+			qla_handle_els_plogi_done(vha, &ea);
3d7c23
 			break;
3d7c23
 
3d7c23
 		case CS_IOCB_ERROR:
3d7c23
-- 
3d7c23
2.13.6
3d7c23