aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/ibm/ibmvnic.c
diff options
context:
space:
mode:
authorJohn Allen <jallen@linux.vnet.ibm.com>2017-05-26 10:30:19 -0400
committerDavid S. Miller <davem@davemloft.net>2017-05-26 15:32:44 -0400
commit017892c1ec15d4efcb30edf9fb56a64c889540c3 (patch)
treec94bf4605f053565a530ed17938e32b4b66b6876 /drivers/net/ethernet/ibm/ibmvnic.c
parentd944c3d60ac9ec6968d97ac5704155d0afac5216 (diff)
ibmvnic: Handle failover after failed init crq
Handle case where phyp sends a failover after failing to send the init crq. Signed-off-by: John Allen <jallen@linux.vnet.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/ibm/ibmvnic.c')
-rw-r--r--drivers/net/ethernet/ibm/ibmvnic.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/drivers/net/ethernet/ibm/ibmvnic.c b/drivers/net/ethernet/ibm/ibmvnic.c
index 4997de425b5c..1f7cf6fbe150 100644
--- a/drivers/net/ethernet/ibm/ibmvnic.c
+++ b/drivers/net/ethernet/ibm/ibmvnic.c
@@ -3167,6 +3167,8 @@ static void ibmvnic_handle_crq(union ibmvnic_crq *crq,
3167 switch (gen_crq->cmd) { 3167 switch (gen_crq->cmd) {
3168 case IBMVNIC_CRQ_INIT: 3168 case IBMVNIC_CRQ_INIT:
3169 dev_info(dev, "Partner initialized\n"); 3169 dev_info(dev, "Partner initialized\n");
3170 adapter->from_passive_init = true;
3171 complete(&adapter->init_done);
3170 break; 3172 break;
3171 case IBMVNIC_CRQ_INIT_COMPLETE: 3173 case IBMVNIC_CRQ_INIT_COMPLETE:
3172 dev_info(dev, "Partner initialization complete\n"); 3174 dev_info(dev, "Partner initialization complete\n");
@@ -3481,11 +3483,18 @@ static int ibmvnic_init(struct ibmvnic_adapter *adapter)
3481 return rc; 3483 return rc;
3482 } 3484 }
3483 3485
3486 adapter->from_passive_init = false;
3487
3484 init_completion(&adapter->init_done); 3488 init_completion(&adapter->init_done);
3485 ibmvnic_send_crq_init(adapter); 3489 ibmvnic_send_crq_init(adapter);
3486 if (!wait_for_completion_timeout(&adapter->init_done, timeout)) { 3490 if (!wait_for_completion_timeout(&adapter->init_done, timeout)) {
3487 dev_err(dev, "Initialization sequence timed out\n"); 3491 dev_err(dev, "Initialization sequence timed out\n");
3488 release_crq_queue(adapter); 3492 return -1;
3493 }
3494
3495 if (adapter->from_passive_init) {
3496 adapter->state = VNIC_OPEN;
3497 adapter->from_passive_init = false;
3489 return -1; 3498 return -1;
3490 } 3499 }
3491 3500