These two functions share the majority of the code, hence merge
them together. In the meanwhile, add a reset pass-in parameter
to differentiate them. Thus, the code is easier to read and to tell
the difference between reset_init and regular init.

Signed-off-by: Lijun Pan <l...@linux.ibm.com>
---
 drivers/net/ethernet/ibm/ibmvnic.c | 65 ++++++------------------------
 1 file changed, 13 insertions(+), 52 deletions(-)

diff --git a/drivers/net/ethernet/ibm/ibmvnic.c 
b/drivers/net/ethernet/ibm/ibmvnic.c
index 4ca4647db72a..47fbe0553570 100644
--- a/drivers/net/ethernet/ibm/ibmvnic.c
+++ b/drivers/net/ethernet/ibm/ibmvnic.c
@@ -104,8 +104,7 @@ static int send_login(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 ibmvnic_init(struct ibmvnic_adapter *);
-static int ibmvnic_reset_init(struct ibmvnic_adapter *);
+static int ibmvnic_reset_init(struct ibmvnic_adapter *, bool reset);
 static void release_crq_queue(struct ibmvnic_adapter *);
 static int __ibmvnic_set_mac(struct net_device *, u8 *);
 static int init_crq_queue(struct ibmvnic_adapter *adapter);
@@ -1868,7 +1867,7 @@ static int do_change_param_reset(struct ibmvnic_adapter 
*adapter,
                return rc;
        }
 
-       rc = ibmvnic_reset_init(adapter);
+       rc = ibmvnic_reset_init(adapter, true);
        if (rc)
                return IBMVNIC_INIT_FAILED;
 
@@ -1986,7 +1985,7 @@ static int do_reset(struct ibmvnic_adapter *adapter,
                        goto out;
                }
 
-               rc = ibmvnic_reset_init(adapter);
+               rc = ibmvnic_reset_init(adapter, true);
                if (rc) {
                        rc = IBMVNIC_INIT_FAILED;
                        goto out;
@@ -2093,7 +2092,7 @@ static int do_hard_reset(struct ibmvnic_adapter *adapter,
                return rc;
        }
 
-       rc = ibmvnic_init(adapter);
+       rc = ibmvnic_reset_init(adapter, false);
        if (rc)
                return rc;
 
@@ -4970,7 +4969,7 @@ static int init_crq_queue(struct ibmvnic_adapter *adapter)
        return retrc;
 }
 
-static int ibmvnic_reset_init(struct ibmvnic_adapter *adapter)
+static int ibmvnic_reset_init(struct ibmvnic_adapter *adapter, bool reset)
 {
        struct device *dev = &adapter->vdev->dev;
        unsigned long timeout = msecs_to_jiffies(30000);
@@ -4979,10 +4978,12 @@ static int ibmvnic_reset_init(struct ibmvnic_adapter 
*adapter)
 
        adapter->from_passive_init = false;
 
-       old_num_rx_queues = adapter->req_rx_queues;
-       old_num_tx_queues = adapter->req_tx_queues;
+       if (reset) {
+               old_num_rx_queues = adapter->req_rx_queues;
+               old_num_tx_queues = adapter->req_tx_queues;
+               reinit_completion(&adapter->init_done);
+       }
 
-       reinit_completion(&adapter->init_done);
        adapter->init_done_rc = 0;
        rc = ibmvnic_send_crq_init(adapter);
        if (rc) {
@@ -5000,7 +5001,8 @@ static int ibmvnic_reset_init(struct ibmvnic_adapter 
*adapter)
                return adapter->init_done_rc;
        }
 
-       if (test_bit(0, &adapter->resetting) && !adapter->wait_for_reset &&
+       if (reset &&
+           test_bit(0, &adapter->resetting) && !adapter->wait_for_reset &&
            adapter->reset_reason != VNIC_RESET_MOBILITY) {
                if (adapter->req_rx_queues != old_num_rx_queues ||
                    adapter->req_tx_queues != old_num_tx_queues) {
@@ -5028,47 +5030,6 @@ static int ibmvnic_reset_init(struct ibmvnic_adapter 
*adapter)
        return rc;
 }
 
-static int ibmvnic_init(struct ibmvnic_adapter *adapter)
-{
-       struct device *dev = &adapter->vdev->dev;
-       unsigned long timeout = msecs_to_jiffies(30000);
-       int rc;
-
-       adapter->from_passive_init = false;
-
-       adapter->init_done_rc = 0;
-       rc = ibmvnic_send_crq_init(adapter);
-       if (rc) {
-               dev_err(dev, "Send crq init failed with error %d\n", rc);
-               return rc;
-       }
-
-       if (!wait_for_completion_timeout(&adapter->init_done, timeout)) {
-               dev_err(dev, "Initialization sequence timed out\n");
-               return -1;
-       }
-
-       if (adapter->init_done_rc) {
-               release_crq_queue(adapter);
-               return adapter->init_done_rc;
-       }
-
-       rc = init_sub_crqs(adapter);
-       if (rc) {
-               dev_err(dev, "Initialization of sub crqs failed\n");
-               release_crq_queue(adapter);
-               return rc;
-       }
-
-       rc = init_sub_crq_irqs(adapter);
-       if (rc) {
-               dev_err(dev, "Failed to initialize sub crq irqs\n");
-               release_crq_queue(adapter);
-       }
-
-       return rc;
-}
-
 static struct device_attribute dev_attr_failover;
 
 static int ibmvnic_probe(struct vio_dev *dev, const struct vio_device_id *id)
@@ -5131,7 +5092,7 @@ static int ibmvnic_probe(struct vio_dev *dev, const 
struct vio_device_id *id)
                        goto ibmvnic_init_fail;
                }
 
-               rc = ibmvnic_init(adapter);
+               rc = ibmvnic_reset_init(adapter, false);
                if (rc && rc != EAGAIN)
                        goto ibmvnic_init_fail;
        } while (rc == EAGAIN);
-- 
2.23.0

Reply via email to