octeon_ep: support Octeon device CNF95N
authorVeerasenareddy Burru <vburru@marvell.com>
Thu, 3 Nov 2022 06:05:57 +0000 (23:05 -0700)
committerJakub Kicinski <kuba@kernel.org>
Sat, 5 Nov 2022 02:54:44 +0000 (19:54 -0700)
Add support for Octeon device CNF95N.
CNF95N is a Octeon Fusion family product with same PCI NIC
characteristics as CN93 which is currently supported by the driver.

update supported device list in Documentation.

Signed-off-by: Veerasenareddy Burru <vburru@marvell.com>
Link: https://lore.kernel.org/r/20221103060600.1858-1-vburru@marvell.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Documentation/networking/device_drivers/ethernet/marvell/octeon_ep.rst
drivers/net/ethernet/marvell/octeon_ep/octep_main.c
drivers/net/ethernet/marvell/octeon_ep/octep_main.h

index bc562c49011b7339e63f38ab48ac6a6a8dd64ef2..cad96c8d1f97dd865ee541885dd8b98c99f28e69 100644 (file)
@@ -23,6 +23,7 @@ Supported Devices
 =================
 Currently, this driver support following devices:
  * Network controller: Cavium, Inc. Device b200
+ * Network controller: Cavium, Inc. Device b400
 
 Interface Control
 =================
index 9089adcb75f92be857fae13006437d7c27035312..1cbfa800a8af4f5f92aaba796954e098284d8b17 100644 (file)
@@ -23,6 +23,7 @@ struct workqueue_struct *octep_wq;
 /* Supported Devices */
 static const struct pci_device_id octep_pci_id_tbl[] = {
        {PCI_DEVICE(PCI_VENDOR_ID_CAVIUM, OCTEP_PCI_DEVICE_ID_CN93_PF)},
+       {PCI_DEVICE(PCI_VENDOR_ID_CAVIUM, OCTEP_PCI_DEVICE_ID_CNF95N_PF)},
        {0, },
 };
 MODULE_DEVICE_TABLE(pci, octep_pci_id_tbl);
@@ -907,6 +908,18 @@ static void octep_ctrl_mbox_task(struct work_struct *work)
        }
 }
 
+static const char *octep_devid_to_str(struct octep_device *oct)
+{
+       switch (oct->chip_id) {
+       case OCTEP_PCI_DEVICE_ID_CN93_PF:
+               return "CN93XX";
+       case OCTEP_PCI_DEVICE_ID_CNF95N_PF:
+               return "CNF95N";
+       default:
+               return "Unsupported";
+       }
+}
+
 /**
  * octep_device_setup() - Setup Octeon Device.
  *
@@ -939,9 +952,10 @@ int octep_device_setup(struct octep_device *oct)
 
        switch (oct->chip_id) {
        case OCTEP_PCI_DEVICE_ID_CN93_PF:
-               dev_info(&pdev->dev,
-                        "Setting up OCTEON CN93XX PF PASS%d.%d\n",
-                        OCTEP_MAJOR_REV(oct), OCTEP_MINOR_REV(oct));
+       case OCTEP_PCI_DEVICE_ID_CNF95N_PF:
+               dev_info(&pdev->dev, "Setting up OCTEON %s PF PASS%d.%d\n",
+                        octep_devid_to_str(oct), OCTEP_MAJOR_REV(oct),
+                        OCTEP_MINOR_REV(oct));
                octep_device_setup_cn93_pf(oct);
                break;
        default:
index 025626a613837cb7ef5c8787bbba77dc14c83101..123ffc13754d819b20c67e3a2ff2a57403bd0628 100644 (file)
@@ -21,6 +21,8 @@
 #define  OCTEP_PCI_DEVICE_ID_CN93_PF 0xB200
 #define  OCTEP_PCI_DEVICE_ID_CN93_VF 0xB203
 
+#define  OCTEP_PCI_DEVICE_ID_CNF95N_PF 0xB400    //95N PF
+
 #define  OCTEP_MAX_QUEUES   63
 #define  OCTEP_MAX_IQ       OCTEP_MAX_QUEUES
 #define  OCTEP_MAX_OQ       OCTEP_MAX_QUEUES