aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/qla2xxx
diff options
context:
space:
mode:
authorSeokmann Ju <seokmann.ju@qlogic.com>2008-07-10 19:55:58 -0400
committerJames Bottomley <James.Bottomley@HansenPartnership.com>2008-07-26 15:14:44 -0400
commit5de1f70f4103253f72d92da16d9618bc573b4534 (patch)
tree0579498b302f9e2d89cbceb610dfb300cdec40cb /drivers/scsi/qla2xxx
parentda57bf8f25faf97308d9f4d0b87e8b69317a2fdf (diff)
[SCSI] qla2xxx: Correct rport/fcport visibility-state handling during loop-resync.
There were several issues here, one, during RSCN handling if a follow-on RSCN occurred (within interrupt context) the DPC thread could inadvertantly leave the fcport in a stale lost state. Secondly, scheduled rport removal is handled exclusively by the 'parent' DPC thread, so wake up the proper thread. Finally, process vport loop-resync's only when the vport has in an "active" state (ID acquired). Signed-off-by: Seokmann Ju <seokmann.ju@qlogic.com> Signed-off-by: Andrew Vasquez <andrew.vasquez@qlogic.com> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/scsi/qla2xxx')
-rw-r--r--drivers/scsi/qla2xxx/qla_init.c4
-rw-r--r--drivers/scsi/qla2xxx/qla_mid.c3
-rw-r--r--drivers/scsi/qla2xxx/qla_os.c5
3 files changed, 8 insertions, 4 deletions
diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c
index 4c83ff81d79b..f8cfeb0e91a6 100644
--- a/drivers/scsi/qla2xxx/qla_init.c
+++ b/drivers/scsi/qla2xxx/qla_init.c
@@ -2012,8 +2012,10 @@ qla2x00_configure_loop(scsi_qla_host_t *ha)
2012 if (test_bit(LOOP_RESYNC_NEEDED, &ha->dpc_flags)) { 2012 if (test_bit(LOOP_RESYNC_NEEDED, &ha->dpc_flags)) {
2013 if (test_bit(LOCAL_LOOP_UPDATE, &save_flags)) 2013 if (test_bit(LOCAL_LOOP_UPDATE, &save_flags))
2014 set_bit(LOCAL_LOOP_UPDATE, &ha->dpc_flags); 2014 set_bit(LOCAL_LOOP_UPDATE, &ha->dpc_flags);
2015 if (test_bit(RSCN_UPDATE, &save_flags)) 2015 if (test_bit(RSCN_UPDATE, &save_flags)) {
2016 ha->flags.rscn_queue_overflow = 1;
2016 set_bit(RSCN_UPDATE, &ha->dpc_flags); 2017 set_bit(RSCN_UPDATE, &ha->dpc_flags);
2018 }
2017 } 2019 }
2018 2020
2019 return (rval); 2021 return (rval);
diff --git a/drivers/scsi/qla2xxx/qla_mid.c b/drivers/scsi/qla2xxx/qla_mid.c
index e7565765fa14..9a850a24b38a 100644
--- a/drivers/scsi/qla2xxx/qla_mid.c
+++ b/drivers/scsi/qla2xxx/qla_mid.c
@@ -277,7 +277,8 @@ qla2x00_do_dpc_vp(scsi_qla_host_t *vha)
277 clear_bit(RESET_ACTIVE, &vha->dpc_flags); 277 clear_bit(RESET_ACTIVE, &vha->dpc_flags);
278 } 278 }
279 279
280 if (test_and_clear_bit(LOOP_RESYNC_NEEDED, &vha->dpc_flags)) { 280 if (atomic_read(&vha->vp_state) == VP_ACTIVE &&
281 test_and_clear_bit(LOOP_RESYNC_NEEDED, &vha->dpc_flags)) {
281 if (!(test_and_set_bit(LOOP_RESYNC_ACTIVE, &vha->dpc_flags))) { 282 if (!(test_and_set_bit(LOOP_RESYNC_ACTIVE, &vha->dpc_flags))) {
282 qla2x00_loop_resync(vha); 283 qla2x00_loop_resync(vha);
283 clear_bit(LOOP_RESYNC_ACTIVE, &vha->dpc_flags); 284 clear_bit(LOOP_RESYNC_ACTIVE, &vha->dpc_flags);
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c
index 3f391698e1ce..0f44914b41d7 100644
--- a/drivers/scsi/qla2xxx/qla_os.c
+++ b/drivers/scsi/qla2xxx/qla_os.c
@@ -1849,6 +1849,7 @@ qla2x00_schedule_rport_del(struct scsi_qla_host *ha, fc_port_t *fcport,
1849 int defer) 1849 int defer)
1850{ 1850{
1851 struct fc_rport *rport; 1851 struct fc_rport *rport;
1852 scsi_qla_host_t *pha = to_qla_parent(ha);
1852 1853
1853 if (!fcport->rport) 1854 if (!fcport->rport)
1854 return; 1855 return;
@@ -1858,8 +1859,8 @@ qla2x00_schedule_rport_del(struct scsi_qla_host *ha, fc_port_t *fcport,
1858 spin_lock_irq(ha->host->host_lock); 1859 spin_lock_irq(ha->host->host_lock);
1859 fcport->drport = rport; 1860 fcport->drport = rport;
1860 spin_unlock_irq(ha->host->host_lock); 1861 spin_unlock_irq(ha->host->host_lock);
1861 set_bit(FCPORT_UPDATE_NEEDED, &ha->dpc_flags); 1862 set_bit(FCPORT_UPDATE_NEEDED, &pha->dpc_flags);
1862 qla2xxx_wake_dpc(ha); 1863 qla2xxx_wake_dpc(pha);
1863 } else 1864 } else
1864 fc_remote_port_delete(rport); 1865 fc_remote_port_delete(rport);
1865} 1866}