diff options
author | John Allen <jallen@linux.vnet.ibm.com> | 2017-05-26 10:30:19 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-05-26 15:32:44 -0400 |
commit | 017892c1ec15d4efcb30edf9fb56a64c889540c3 (patch) | |
tree | c94bf4605f053565a530ed17938e32b4b66b6876 /drivers/net/ethernet/ibm/ibmvnic.c | |
parent | d944c3d60ac9ec6968d97ac5704155d0afac5216 (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.c | 11 |
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 | ||