diff options
author | Seokmann Ju <seokmann.ju@qlogic.com> | 2008-07-10 19:55:58 -0400 |
---|---|---|
committer | James Bottomley <James.Bottomley@HansenPartnership.com> | 2008-07-26 15:14:44 -0400 |
commit | 5de1f70f4103253f72d92da16d9618bc573b4534 (patch) | |
tree | 0579498b302f9e2d89cbceb610dfb300cdec40cb /drivers/scsi/qla2xxx | |
parent | da57bf8f25faf97308d9f4d0b87e8b69317a2fdf (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.c | 4 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_mid.c | 3 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_os.c | 5 |
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 | } |