aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
authorVijay Mohan Guvva <vmohan@Brocade.com>2013-05-13 05:49:44 -0400
committerJames Bottomley <JBottomley@Parallels.com>2013-06-04 14:16:25 -0400
commit111ecbe426241bdc89c33e9acd08eb15744ce031 (patch)
tree4f4add6a338b5bdb1a1468c1914afa877e955c3b /drivers/scsi
parent0816c9251a7180383bb7811e1a1545f7b78e5374 (diff)
[SCSI] bfa: fix faulty handling of events in lps sm
When a switch disable/enable or a reboot is done, the HBA port gets an offline and a subsequent online notification. When the port comes up a link up notification is sent to bfa from the firmware. The bfa then send an FLOGI to the firmware which is sent out on the wire. The switch port meanwhile goes offline (presumably for diagnostics) which causes the switch not to respond to the FLOGI. The link down notification is sent to the HBA driver. However owing to a bug in the lps state machine handling the lps state machine does not move to sm_init state (it remains in sm_login state and send a login complete message to fcs). This results in a zero PID assignment as the login is not really complete. This fix is to correctly handle the events in lps state machine. Signed-off-by: Vijaya Mohan Guvva <vmohan@brocade.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/bfa/bfa_svc.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/scsi/bfa/bfa_svc.c b/drivers/scsi/bfa/bfa_svc.c
index 299c1c889b33..7ed2c57d8736 100644
--- a/drivers/scsi/bfa/bfa_svc.c
+++ b/drivers/scsi/bfa/bfa_svc.c
@@ -1276,7 +1276,6 @@ bfa_lps_sm_login(struct bfa_lps_s *lps, enum bfa_lps_event event)
1276 1276
1277 switch (event) { 1277 switch (event) {
1278 case BFA_LPS_SM_FWRSP: 1278 case BFA_LPS_SM_FWRSP:
1279 case BFA_LPS_SM_OFFLINE:
1280 if (lps->status == BFA_STATUS_OK) { 1279 if (lps->status == BFA_STATUS_OK) {
1281 bfa_sm_set_state(lps, bfa_lps_sm_online); 1280 bfa_sm_set_state(lps, bfa_lps_sm_online);
1282 if (lps->fdisc) 1281 if (lps->fdisc)
@@ -1305,6 +1304,7 @@ bfa_lps_sm_login(struct bfa_lps_s *lps, enum bfa_lps_event event)
1305 bfa_lps_login_comp(lps); 1304 bfa_lps_login_comp(lps);
1306 break; 1305 break;
1307 1306
1307 case BFA_LPS_SM_OFFLINE:
1308 case BFA_LPS_SM_DELETE: 1308 case BFA_LPS_SM_DELETE:
1309 bfa_sm_set_state(lps, bfa_lps_sm_init); 1309 bfa_sm_set_state(lps, bfa_lps_sm_init);
1310 break; 1310 break;