|
@@ -111,6 +111,7 @@ static void send_request_map(struct ibmvnic_adapter *, dma_addr_t, __be32, u8);
|
|
static void send_request_unmap(struct ibmvnic_adapter *, u8);
|
|
static void send_request_unmap(struct ibmvnic_adapter *, u8);
|
|
static void send_login(struct ibmvnic_adapter *adapter);
|
|
static void send_login(struct ibmvnic_adapter *adapter);
|
|
static void send_cap_queries(struct ibmvnic_adapter *adapter);
|
|
static void send_cap_queries(struct ibmvnic_adapter *adapter);
|
|
|
|
+static int init_sub_crqs(struct ibmvnic_adapter *);
|
|
static int init_sub_crq_irqs(struct ibmvnic_adapter *adapter);
|
|
static int init_sub_crq_irqs(struct ibmvnic_adapter *adapter);
|
|
static int ibmvnic_init(struct ibmvnic_adapter *);
|
|
static int ibmvnic_init(struct ibmvnic_adapter *);
|
|
static void release_crq_queue(struct ibmvnic_adapter *);
|
|
static void release_crq_queue(struct ibmvnic_adapter *);
|
|
@@ -651,6 +652,7 @@ static int ibmvnic_login(struct net_device *netdev)
|
|
struct ibmvnic_adapter *adapter = netdev_priv(netdev);
|
|
struct ibmvnic_adapter *adapter = netdev_priv(netdev);
|
|
unsigned long timeout = msecs_to_jiffies(30000);
|
|
unsigned long timeout = msecs_to_jiffies(30000);
|
|
struct device *dev = &adapter->vdev->dev;
|
|
struct device *dev = &adapter->vdev->dev;
|
|
|
|
+ int rc;
|
|
|
|
|
|
do {
|
|
do {
|
|
if (adapter->renegotiate) {
|
|
if (adapter->renegotiate) {
|
|
@@ -664,6 +666,18 @@ static int ibmvnic_login(struct net_device *netdev)
|
|
dev_err(dev, "Capabilities query timeout\n");
|
|
dev_err(dev, "Capabilities query timeout\n");
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
+ rc = init_sub_crqs(adapter);
|
|
|
|
+ if (rc) {
|
|
|
|
+ dev_err(dev,
|
|
|
|
+ "Initialization of SCRQ's failed\n");
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
+ rc = init_sub_crq_irqs(adapter);
|
|
|
|
+ if (rc) {
|
|
|
|
+ dev_err(dev,
|
|
|
|
+ "Initialization of SCRQ's irqs failed\n");
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
reinit_completion(&adapter->init_done);
|
|
reinit_completion(&adapter->init_done);
|
|
@@ -3004,7 +3018,6 @@ static void handle_request_cap_rsp(union ibmvnic_crq *crq,
|
|
*req_value,
|
|
*req_value,
|
|
(long int)be64_to_cpu(crq->request_capability_rsp.
|
|
(long int)be64_to_cpu(crq->request_capability_rsp.
|
|
number), name);
|
|
number), name);
|
|
- release_sub_crqs(adapter);
|
|
|
|
*req_value = be64_to_cpu(crq->request_capability_rsp.number);
|
|
*req_value = be64_to_cpu(crq->request_capability_rsp.number);
|
|
ibmvnic_send_req_caps(adapter, 1);
|
|
ibmvnic_send_req_caps(adapter, 1);
|
|
return;
|
|
return;
|