[SCSI] qla2xxx: Correct infinite-login-retry issue.

Where the DPC logic would get jammed into continuously
reloging-into a port.

Signed-off-by: Andrew Vasquez <andrew.vasquez@qlogic.com>
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
This commit is contained in:
Ravi Anand 2007-09-20 14:07:40 -07:00 committed by James Bottomley
parent b583692739
commit 63a8651f25
1 changed files with 3 additions and 1 deletions

View File

@ -2437,7 +2437,6 @@ qla2x00_do_dpc(void *data)
if (atomic_read(&fcport->state) != FCS_ONLINE && if (atomic_read(&fcport->state) != FCS_ONLINE &&
fcport->login_retry) { fcport->login_retry) {
fcport->login_retry--;
if (fcport->flags & FCF_FABRIC_DEVICE) { if (fcport->flags & FCF_FABRIC_DEVICE) {
if (fcport->flags & if (fcport->flags &
FCF_TAPE_PRESENT) FCF_TAPE_PRESENT)
@ -2453,6 +2452,7 @@ qla2x00_do_dpc(void *data)
qla2x00_local_device_login( qla2x00_local_device_login(
ha, fcport); ha, fcport);
fcport->login_retry--;
if (status == QLA_SUCCESS) { if (status == QLA_SUCCESS) {
fcport->old_loop_id = fcport->loop_id; fcport->old_loop_id = fcport->loop_id;
@ -2470,6 +2470,8 @@ qla2x00_do_dpc(void *data)
} else { } else {
fcport->login_retry = 0; fcport->login_retry = 0;
} }
if (fcport->login_retry == 0)
fcport->loop_id = FC_NO_LOOP_ID;
} }
if (test_bit(LOOP_RESYNC_NEEDED, &ha->dpc_flags)) if (test_bit(LOOP_RESYNC_NEEDED, &ha->dpc_flags))
break; break;