OSDN Git Service

net: hns3: add support for registering devlink for PF
authorYufeng Mo <moyufeng@huawei.com>
Mon, 26 Jul 2021 02:47:02 +0000 (10:47 +0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 26 Jul 2021 11:16:03 +0000 (12:16 +0100)
Add devlink register support for HNS3 ethernet PF driver.

Signed-off-by: Yufeng Mo <moyufeng@huawei.com>
Signed-off-by: Guangbin Huang <huangguangbin2@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/hisilicon/Kconfig
drivers/net/ethernet/hisilicon/hns3/hns3pf/Makefile
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_devlink.c [new file with mode: 0644]
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_devlink.h [new file with mode: 0644]
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.h

index bb062b0..094e4a3 100644 (file)
@@ -90,6 +90,7 @@ config HNS_ENET
 config HNS3
        tristate "Hisilicon Network Subsystem Support HNS3 (Framework)"
        depends on PCI
+       select NET_DEVLINK
        help
          This selects the framework support for Hisilicon Network Subsystem 3.
          This layer facilitates clients like ENET, RoCE and user-space ethernet
index a685392..d1bf5c4 100644 (file)
@@ -7,6 +7,6 @@ ccflags-y := -I $(srctree)/drivers/net/ethernet/hisilicon/hns3
 ccflags-y += -I $(srctree)/$(src)
 
 obj-$(CONFIG_HNS3_HCLGE) += hclge.o
-hclge-objs = hclge_main.o hclge_cmd.o hclge_mdio.o hclge_tm.o hclge_mbx.o hclge_err.o  hclge_debugfs.o hclge_ptp.o
+hclge-objs = hclge_main.o hclge_cmd.o hclge_mdio.o hclge_tm.o hclge_mbx.o hclge_err.o  hclge_debugfs.o hclge_ptp.o hclge_devlink.o
 
 hclge-$(CONFIG_HNS3_DCB) += hclge_dcb.o
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_devlink.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_devlink.c
new file mode 100644 (file)
index 0000000..03b822b
--- /dev/null
@@ -0,0 +1,54 @@
+// SPDX-License-Identifier: GPL-2.0+
+/* Copyright (c) 2021 Hisilicon Limited. */
+
+#include <net/devlink.h>
+
+#include "hclge_devlink.h"
+
+static const struct devlink_ops hclge_devlink_ops = {
+};
+
+int hclge_devlink_init(struct hclge_dev *hdev)
+{
+       struct pci_dev *pdev = hdev->pdev;
+       struct hclge_devlink_priv *priv;
+       struct devlink *devlink;
+       int ret;
+
+       devlink = devlink_alloc(&hclge_devlink_ops,
+                               sizeof(struct hclge_devlink_priv));
+       if (!devlink)
+               return -ENOMEM;
+
+       priv = devlink_priv(devlink);
+       priv->hdev = hdev;
+
+       ret = devlink_register(devlink, &pdev->dev);
+       if (ret) {
+               dev_err(&pdev->dev, "failed to register devlink, ret = %d\n",
+                       ret);
+               goto out_reg_fail;
+       }
+
+       hdev->devlink = devlink;
+
+       return 0;
+
+out_reg_fail:
+       devlink_free(devlink);
+       return ret;
+}
+
+void hclge_devlink_uninit(struct hclge_dev *hdev)
+{
+       struct devlink *devlink = hdev->devlink;
+
+       if (!devlink)
+               return;
+
+       devlink_unregister(devlink);
+
+       devlink_free(devlink);
+
+       hdev->devlink = NULL;
+}
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_devlink.h b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_devlink.h
new file mode 100644 (file)
index 0000000..918be04
--- /dev/null
@@ -0,0 +1,15 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/* Copyright (c) 2021 Hisilicon Limited. */
+
+#ifndef __HCLGE_DEVLINK_H
+#define __HCLGE_DEVLINK_H
+
+#include "hclge_main.h"
+
+struct hclge_devlink_priv {
+       struct hclge_dev *hdev;
+};
+
+int hclge_devlink_init(struct hclge_dev *hdev);
+void hclge_devlink_uninit(struct hclge_dev *hdev);
+#endif
index ebeaf12..f15d76e 100644 (file)
@@ -23,6 +23,7 @@
 #include "hclge_tm.h"
 #include "hclge_err.h"
 #include "hnae3.h"
+#include "hclge_devlink.h"
 
 #define HCLGE_NAME                     "hclge"
 #define HCLGE_STATS_READ(p, offset) (*(u64 *)((u8 *)(p) + (offset)))
@@ -11482,10 +11483,14 @@ 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;
+
        /* Firmware command queue initialize */
        ret = hclge_cmd_queue_init(hdev);
        if (ret)
-               goto err_pci_uninit;
+               goto err_devlink_uninit;
 
        /* Firmware command initialize */
        ret = hclge_cmd_init(hdev);
@@ -11658,6 +11663,8 @@ err_msi_uninit:
        pci_free_irq_vectors(pdev);
 err_cmd_uninit:
        hclge_cmd_uninit(hdev);
+err_devlink_uninit:
+       hclge_devlink_uninit(hdev);
 err_pci_uninit:
        pcim_iounmap(pdev, hdev->hw.io_base);
        pci_clear_master(pdev);
@@ -12048,6 +12055,7 @@ static void hclge_uninit_ae_dev(struct hnae3_ae_dev *ae_dev)
 
        hclge_cmd_uninit(hdev);
        hclge_misc_irq_uninit(hdev);
+       hclge_devlink_uninit(hdev);
        hclge_pci_uninit(hdev);
        mutex_destroy(&hdev->vport_lock);
        hclge_uninit_vport_vlan_table(hdev);
index 3d33524..cc31b12 100644 (file)
@@ -8,6 +8,7 @@
 #include <linux/phy.h>
 #include <linux/if_vlan.h>
 #include <linux/kfifo.h>
+#include <net/devlink.h>
 
 #include "hclge_cmd.h"
 #include "hclge_ptp.h"
@@ -943,6 +944,7 @@ struct hclge_dev {
        cpumask_t affinity_mask;
        struct irq_affinity_notify affinity_notify;
        struct hclge_ptp *ptp;
+       struct devlink *devlink;
 };
 
 /* VPort level vlan tag configuration for TX direction */