Commit 99363ef8 authored by Seokmann Ju's avatar Seokmann Ju Committed by James Bottomley

[SCSI] qla2xxx: Correct issue where vport-state was not updated during an ISP_ABORT_NEEDED requst.

While running IO simultaneously through physical port and virtual
port, if user changes Data Rate (from scli utility), IO through
virtual port fails.  It failed because the vport had not received
the ISP_ABORT_NEEDED notification.
Signed-Off-by: default avatarSeokmann Ju <seokmann.ju@qlogic.com>
Signed-off-by: default avatarAndrew Vasquez <andrew.vasquez@qlogic.com>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
parent 963b0fdd
...@@ -2227,6 +2227,9 @@ qla2x00_do_dpc(void *data) ...@@ -2227,6 +2227,9 @@ qla2x00_do_dpc(void *data)
fc_port_t *fcport; fc_port_t *fcport;
uint8_t status; uint8_t status;
uint16_t next_loopid; uint16_t next_loopid;
struct scsi_qla_host *vha;
int i;
ha = (scsi_qla_host_t *)data; ha = (scsi_qla_host_t *)data;
...@@ -2269,6 +2272,18 @@ qla2x00_do_dpc(void *data) ...@@ -2269,6 +2272,18 @@ qla2x00_do_dpc(void *data)
} }
clear_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags); clear_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags);
} }
for_each_mapped_vp_idx(ha, i) {
list_for_each_entry(vha, &ha->vp_list,
vp_list) {
if (i == vha->vp_idx) {
set_bit(ISP_ABORT_NEEDED,
&vha->dpc_flags);
break;
}
}
}
DEBUG(printk("scsi(%ld): dpc: qla2x00_abort_isp end\n", DEBUG(printk("scsi(%ld): dpc: qla2x00_abort_isp end\n",
ha->host_no)); ha->host_no));
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment