]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
net: hns3: fix kernel crash when devlink reload during initialization
authorYonglong Liu <liuyonglong@huawei.com>
Tue, 7 May 2024 13:42:24 +0000 (21:42 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 17 May 2024 10:02:25 +0000 (12:02 +0200)
[ Upstream commit 35d92abfbad88cf947c010baf34b075e40566095 ]

The devlink reload process will access the hardware resources,
but the register operation is done before the hardware is initialized.
So, processing the devlink reload during initialization may lead to kernel
crash.

This patch fixes this by registering the devlink after
hardware initialization.

Fixes: cd6242991d2e ("net: hns3: add support for registering devlink for VF")
Fixes: 93305b77ffcb ("net: hns3: fix kernel crash when devlink reload during pf initialization")
Signed-off-by: Yonglong Liu <liuyonglong@huawei.com>
Signed-off-by: Jijie Shao <shaojijie@huawei.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
drivers/net/ethernet/hisilicon/hns3/hns3vf/hclgevf_main.c

index 3b74cce46ac653802a11124d484b4906d3671bbf..14713454e0d8217976d2cecd81657d9269a29e97 100644 (file)
@@ -11619,16 +11619,10 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev)
        if (ret)
                goto out;
 
-       ret = hclge_devlink_init(hdev);
-       if (ret)
-               goto err_pci_uninit;
-
-       devl_lock(hdev->devlink);
-
        /* Firmware command queue initialize */
        ret = hclge_comm_cmd_queue_init(hdev->pdev, &hdev->hw.hw);
        if (ret)
-               goto err_devlink_uninit;
+               goto err_pci_uninit;
 
        /* Firmware command initialize */
        ret = hclge_comm_cmd_init(hdev->ae_dev, &hdev->hw.hw, &hdev->fw_version,
@@ -11796,6 +11790,10 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev)
                dev_warn(&pdev->dev,
                         "failed to wake on lan init, ret = %d\n", ret);
 
+       ret = hclge_devlink_init(hdev);
+       if (ret)
+               goto err_ptp_uninit;
+
        hclge_state_init(hdev);
        hdev->last_reset_time = jiffies;
 
@@ -11803,8 +11801,6 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev)
                 HCLGE_DRIVER_NAME);
 
        hclge_task_schedule(hdev, round_jiffies_relative(HZ));
-
-       devl_unlock(hdev->devlink);
        return 0;
 
 err_ptp_uninit:
@@ -11818,9 +11814,6 @@ err_msi_uninit:
        pci_free_irq_vectors(pdev);
 err_cmd_uninit:
        hclge_comm_cmd_uninit(hdev->ae_dev, &hdev->hw.hw);
-err_devlink_uninit:
-       devl_unlock(hdev->devlink);
-       hclge_devlink_uninit(hdev);
 err_pci_uninit:
        pcim_iounmap(pdev, hdev->hw.hw.io_base);
        pci_release_regions(pdev);
index 08db8e84be4ed2b96d068c9965d79bed682b02c5..43ee20eb03d1fb1abf9b655661bf5f572c5de82e 100644 (file)
@@ -2845,10 +2845,6 @@ static int hclgevf_init_hdev(struct hclgevf_dev *hdev)
        if (ret)
                return ret;
 
-       ret = hclgevf_devlink_init(hdev);
-       if (ret)
-               goto err_devlink_init;
-
        ret = hclge_comm_cmd_queue_init(hdev->pdev, &hdev->hw.hw);
        if (ret)
                goto err_cmd_queue_init;
@@ -2941,6 +2937,10 @@ static int hclgevf_init_hdev(struct hclgevf_dev *hdev)
 
        hclgevf_init_rxd_adv_layout(hdev);
 
+       ret = hclgevf_devlink_init(hdev);
+       if (ret)
+               goto err_config;
+
        set_bit(HCLGEVF_STATE_SERVICE_INITED, &hdev->state);
 
        hdev->last_reset_time = jiffies;
@@ -2960,8 +2960,6 @@ err_misc_irq_init:
 err_cmd_init:
        hclge_comm_cmd_uninit(hdev->ae_dev, &hdev->hw.hw);
 err_cmd_queue_init:
-       hclgevf_devlink_uninit(hdev);
-err_devlink_init:
        hclgevf_pci_uninit(hdev);
        clear_bit(HCLGEVF_STATE_IRQ_INITED, &hdev->state);
        return ret;