aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/ibmvscsi
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/ibmvscsi')
-rw-r--r--drivers/scsi/ibmvscsi/ibmvfc.c15
1 files changed, 6 insertions, 9 deletions
diff --git a/drivers/scsi/ibmvscsi/ibmvfc.c b/drivers/scsi/ibmvscsi/ibmvfc.c
index d37230faf086..696328699ec3 100644
--- a/drivers/scsi/ibmvscsi/ibmvfc.c
+++ b/drivers/scsi/ibmvscsi/ibmvfc.c
@@ -558,12 +558,11 @@ static void ibmvfc_link_down(struct ibmvfc_host *vhost,
558/** 558/**
559 * ibmvfc_init_host - Start host initialization 559 * ibmvfc_init_host - Start host initialization
560 * @vhost: ibmvfc host struct 560 * @vhost: ibmvfc host struct
561 * @relogin: is this a re-login?
562 * 561 *
563 * Return value: 562 * Return value:
564 * nothing 563 * nothing
565 **/ 564 **/
566static void ibmvfc_init_host(struct ibmvfc_host *vhost, int relogin) 565static void ibmvfc_init_host(struct ibmvfc_host *vhost)
567{ 566{
568 struct ibmvfc_target *tgt; 567 struct ibmvfc_target *tgt;
569 568
@@ -577,10 +576,8 @@ static void ibmvfc_init_host(struct ibmvfc_host *vhost, int relogin)
577 } 576 }
578 577
579 if (!ibmvfc_set_host_state(vhost, IBMVFC_INITIALIZING)) { 578 if (!ibmvfc_set_host_state(vhost, IBMVFC_INITIALIZING)) {
580 if (!relogin) { 579 memset(vhost->async_crq.msgs, 0, PAGE_SIZE);
581 memset(vhost->async_crq.msgs, 0, PAGE_SIZE); 580 vhost->async_crq.cur = 0;
582 vhost->async_crq.cur = 0;
583 }
584 581
585 list_for_each_entry(tgt, &vhost->targets, queue) 582 list_for_each_entry(tgt, &vhost->targets, queue)
586 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT); 583 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT);
@@ -2303,13 +2300,13 @@ static void ibmvfc_handle_crq(struct ibmvfc_crq *crq, struct ibmvfc_host *vhost)
2303 /* Send back a response */ 2300 /* Send back a response */
2304 rc = ibmvfc_send_crq_init_complete(vhost); 2301 rc = ibmvfc_send_crq_init_complete(vhost);
2305 if (rc == 0) 2302 if (rc == 0)
2306 ibmvfc_init_host(vhost, 0); 2303 ibmvfc_init_host(vhost);
2307 else 2304 else
2308 dev_err(vhost->dev, "Unable to send init rsp. rc=%ld\n", rc); 2305 dev_err(vhost->dev, "Unable to send init rsp. rc=%ld\n", rc);
2309 break; 2306 break;
2310 case IBMVFC_CRQ_INIT_COMPLETE: 2307 case IBMVFC_CRQ_INIT_COMPLETE:
2311 dev_info(vhost->dev, "Partner initialization complete\n"); 2308 dev_info(vhost->dev, "Partner initialization complete\n");
2312 ibmvfc_init_host(vhost, 0); 2309 ibmvfc_init_host(vhost);
2313 break; 2310 break;
2314 default: 2311 default:
2315 dev_err(vhost->dev, "Unknown crq message type: %d\n", crq->format); 2312 dev_err(vhost->dev, "Unknown crq message type: %d\n", crq->format);
@@ -3731,7 +3728,7 @@ static void ibmvfc_npiv_logout_done(struct ibmvfc_event *evt)
3731 case IBMVFC_MAD_SUCCESS: 3728 case IBMVFC_MAD_SUCCESS:
3732 if (list_empty(&vhost->sent) && 3729 if (list_empty(&vhost->sent) &&
3733 vhost->action == IBMVFC_HOST_ACTION_LOGO_WAIT) { 3730 vhost->action == IBMVFC_HOST_ACTION_LOGO_WAIT) {
3734 ibmvfc_init_host(vhost, 0); 3731 ibmvfc_init_host(vhost);
3735 return; 3732 return;
3736 } 3733 }
3737 break; 3734 break;