aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/qla2xxx/qla_dbg.c2
-rw-r--r--drivers/scsi/qla2xxx/qla_init.c13
-rw-r--r--drivers/scsi/qla2xxx/qla_mbx.c7
3 files changed, 18 insertions, 4 deletions
diff --git a/drivers/scsi/qla2xxx/qla_dbg.c b/drivers/scsi/qla2xxx/qla_dbg.c
index 7e9d8f08b9d5..1abc8a9064b3 100644
--- a/drivers/scsi/qla2xxx/qla_dbg.c
+++ b/drivers/scsi/qla2xxx/qla_dbg.c
@@ -60,7 +60,7 @@
60 * | | | 0xb13c-0xb140 | 60 * | | | 0xb13c-0xb140 |
61 * | | | 0xb149 | 61 * | | | 0xb149 |
62 * | MultiQ | 0xc010 | | 62 * | MultiQ | 0xc010 | |
63 * | Misc | 0xd302 | 0xd031-0xd0ff | 63 * | Misc | 0xd303 | 0xd031-0xd0ff |
64 * | | | 0xd101-0xd1fe | 64 * | | | 0xd101-0xd1fe |
65 * | | | 0xd214-0xd2fe | 65 * | | | 0xd214-0xd2fe |
66 * | Target Mode | 0xe081 | | 66 * | Target Mode | 0xe081 | |
diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c
index 33823d74c782..15a96dc205d0 100644
--- a/drivers/scsi/qla2xxx/qla_init.c
+++ b/drivers/scsi/qla2xxx/qla_init.c
@@ -880,7 +880,6 @@ qla24xx_async_prli(struct scsi_qla_host *vha, fc_port_t *fcport)
880 return rval; 880 return rval;
881 881
882 if (fcport->fw_login_state == DSC_LS_PLOGI_PEND || 882 if (fcport->fw_login_state == DSC_LS_PLOGI_PEND ||
883 fcport->fw_login_state == DSC_LS_PLOGI_COMP ||
884 fcport->fw_login_state == DSC_LS_PRLI_PEND) 883 fcport->fw_login_state == DSC_LS_PRLI_PEND)
885 return rval; 884 return rval;
886 885
@@ -1238,6 +1237,11 @@ int qla24xx_fcport_handle_login(struct scsi_qla_host *vha, fc_port_t *fcport)
1238 qla2x00_post_async_adisc_work(vha, fcport, data); 1237 qla2x00_post_async_adisc_work(vha, fcport, data);
1239 break; 1238 break;
1240 1239
1240 case DSC_LOGIN_PEND:
1241 if (fcport->fw_login_state == DSC_LS_PLOGI_COMP)
1242 qla24xx_post_prli_work(vha, fcport);
1243 break;
1244
1241 default: 1245 default:
1242 break; 1246 break;
1243 } 1247 }
@@ -1640,6 +1644,13 @@ qla24xx_handle_prli_done_event(struct scsi_qla_host *vha, struct event_arg *ea)
1640 qla24xx_post_gpdb_work(vha, ea->fcport, 0); 1644 qla24xx_post_gpdb_work(vha, ea->fcport, 0);
1641 break; 1645 break;
1642 default: 1646 default:
1647 if ((ea->iop[0] == LSC_SCODE_ELS_REJECT) &&
1648 (ea->iop[1] == 0x50000)) { /* reson 5=busy expl:0x0 */
1649 set_bit(RELOGIN_NEEDED, &vha->dpc_flags);
1650 ea->fcport->fw_login_state = DSC_LS_PLOGI_COMP;
1651 break;
1652 }
1653
1643 if (ea->fcport->n2n_flag) { 1654 if (ea->fcport->n2n_flag) {
1644 ql_dbg(ql_dbg_disc, vha, 0x2118, 1655 ql_dbg(ql_dbg_disc, vha, 0x2118,
1645 "%s %d %8phC post fc4 prli\n", 1656 "%s %d %8phC post fc4 prli\n",
diff --git a/drivers/scsi/qla2xxx/qla_mbx.c b/drivers/scsi/qla2xxx/qla_mbx.c
index 735079ba691c..c9a134ae0d2b 100644
--- a/drivers/scsi/qla2xxx/qla_mbx.c
+++ b/drivers/scsi/qla2xxx/qla_mbx.c
@@ -1025,9 +1025,12 @@ qla2x00_get_fw_version(scsi_qla_host_t *vha)
1025 * FW supports nvme and driver load parameter requested nvme. 1025 * FW supports nvme and driver load parameter requested nvme.
1026 * BIT 26 of fw_attributes indicates NVMe support. 1026 * BIT 26 of fw_attributes indicates NVMe support.
1027 */ 1027 */
1028 if ((ha->fw_attributes_h & 0x400) && ql2xnvmeenable) 1028 if ((ha->fw_attributes_h & 0x400) && ql2xnvmeenable) {
1029 vha->flags.nvme_enabled = 1; 1029 vha->flags.nvme_enabled = 1;
1030 1030 ql_log(ql_log_info, vha, 0xd302,
1031 "%s: FC-NVMe is Enabled (0x%x)\n",
1032 __func__, ha->fw_attributes_h);
1033 }
1031 } 1034 }
1032 1035
1033 if (IS_QLA27XX(ha)) { 1036 if (IS_QLA27XX(ha)) {