diff options
author | Darren Trapp <darren.trapp@cavium.com> | 2018-03-21 02:09:37 -0400 |
---|---|---|
committer | Martin K. Petersen <martin.petersen@oracle.com> | 2018-03-21 18:38:54 -0400 |
commit | 1cbc0efcd9bee74670d0b637f53e67c47373f544 (patch) | |
tree | 2a382822417f704658a9f8aaf94fb76874e1a4b6 | |
parent | 2e4c5d2ef76b6f04a3cb7a15bc0fee0ab029dedf (diff) |
scsi: qla2xxx: Fix retry for PRLI RJT with reason of BUSY
Signed-off-by: Darren Trapp <darren.trapp@cavium.com>
Signed-off-by: Himanshu Madhani <himanshu.madhani@cavium.com>
Reviewed-by: Hannes Reinecke <hare@suse.com>
Reviewed-by: Johannes Thumshirn <jthumshirn@suse.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r-- | drivers/scsi/qla2xxx/qla_dbg.c | 2 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_init.c | 13 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_mbx.c | 7 |
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)) { |