mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-22 05:44:31 +08:00
[SCSI] qla2xxx: Correct inadvertent loop state transitions during port-update handling.
Transitioning to a LOOP_UPDATE loop-state could cause the driver to miss normal link/target processing. LOOP_UPDATE is a crufty artifact leftover from at time the driver performed it's own internal command-queuing. Safely remove this state. Signed-off-by: Andrew Vasquez <andrew.vasquez@qlogic.com> Signed-off-by: Chad Dupuis <chad.dupuis@qlogic.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
This commit is contained in:
parent
3553d343e7
commit
58b4857696
@ -3838,15 +3838,12 @@ qla2x00_loop_resync(scsi_qla_host_t *vha)
|
||||
req = vha->req;
|
||||
rsp = req->rsp;
|
||||
|
||||
atomic_set(&vha->loop_state, LOOP_UPDATE);
|
||||
clear_bit(ISP_ABORT_RETRY, &vha->dpc_flags);
|
||||
if (vha->flags.online) {
|
||||
if (!(rval = qla2x00_fw_ready(vha))) {
|
||||
/* Wait at most MAX_TARGET RSCNs for a stable link. */
|
||||
wait_time = 256;
|
||||
do {
|
||||
atomic_set(&vha->loop_state, LOOP_UPDATE);
|
||||
|
||||
/* Issue a marker after FW becomes ready. */
|
||||
qla2x00_marker(vha, req, rsp, 0, 0,
|
||||
MK_SYNC_ALL);
|
||||
|
@ -719,7 +719,6 @@ skip_rio:
|
||||
vha->flags.rscn_queue_overflow = 1;
|
||||
}
|
||||
|
||||
atomic_set(&vha->loop_state, LOOP_UPDATE);
|
||||
atomic_set(&vha->loop_down_timer, 0);
|
||||
vha->flags.management_server_logged_in = 0;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user