Commit 017892c1 authored by John Allen's avatar John Allen Committed by David S. Miller

ibmvnic: Handle failover after failed init crq

Handle case where phyp sends a failover after failing to send the
init crq.
Signed-off-by: default avatarJohn Allen <jallen@linux.vnet.ibm.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d944c3d6
...@@ -3167,6 +3167,8 @@ static void ibmvnic_handle_crq(union ibmvnic_crq *crq, ...@@ -3167,6 +3167,8 @@ static void ibmvnic_handle_crq(union ibmvnic_crq *crq,
switch (gen_crq->cmd) { switch (gen_crq->cmd) {
case IBMVNIC_CRQ_INIT: case IBMVNIC_CRQ_INIT:
dev_info(dev, "Partner initialized\n"); dev_info(dev, "Partner initialized\n");
adapter->from_passive_init = true;
complete(&adapter->init_done);
break; break;
case IBMVNIC_CRQ_INIT_COMPLETE: case IBMVNIC_CRQ_INIT_COMPLETE:
dev_info(dev, "Partner initialization complete\n"); dev_info(dev, "Partner initialization complete\n");
...@@ -3481,11 +3483,18 @@ static int ibmvnic_init(struct ibmvnic_adapter *adapter) ...@@ -3481,11 +3483,18 @@ static int ibmvnic_init(struct ibmvnic_adapter *adapter)
return rc; return rc;
} }
adapter->from_passive_init = false;
init_completion(&adapter->init_done); init_completion(&adapter->init_done);
ibmvnic_send_crq_init(adapter); ibmvnic_send_crq_init(adapter);
if (!wait_for_completion_timeout(&adapter->init_done, timeout)) { if (!wait_for_completion_timeout(&adapter->init_done, timeout)) {
dev_err(dev, "Initialization sequence timed out\n"); dev_err(dev, "Initialization sequence timed out\n");
release_crq_queue(adapter); return -1;
}
if (adapter->from_passive_init) {
adapter->state = VNIC_OPEN;
adapter->from_passive_init = false;
return -1; return -1;
} }
......
...@@ -1031,5 +1031,5 @@ struct ibmvnic_adapter { ...@@ -1031,5 +1031,5 @@ struct ibmvnic_adapter {
struct list_head rwi_list; struct list_head rwi_list;
struct work_struct ibmvnic_reset; struct work_struct ibmvnic_reset;
bool resetting; bool resetting;
bool napi_enabled; bool napi_enabled, from_passive_init;
}; };
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment