Add support for a new type of NIC NFP3800 card, and update some
network card data acquisition interface functions.

Signed-off-by: Jin Liu <jin....@corigine.com>
Signed-off-by: Diana Wang <na.w...@corigine.com>
Signed-off-by: Peng Zhang <peng.zh...@corigine.com>
Signed-off-by: Chaoyong He <chaoyong...@corigine.com>
Signed-off-by: Niklas Söderlund <niklas.soderl...@corigine.com>
---
 drivers/net/nfp/nfp_common.h          | 33 +++++++++++++++++++++++++--
 drivers/net/nfp/nfp_ethdev.c          | 28 ++++++++++++++++++++---
 drivers/net/nfp/nfp_ethdev_vf.c       |  9 ++++++--
 drivers/net/nfp/nfpcore/nfp_cpp.h     |  2 +-
 drivers/net/nfp/nfpcore/nfp_nsp_eth.c | 20 ++++++++++++----
 5 files changed, 79 insertions(+), 13 deletions(-)

diff --git a/drivers/net/nfp/nfp_common.h b/drivers/net/nfp/nfp_common.h
index 1dd230bcc6..346fece527 100644
--- a/drivers/net/nfp/nfp_common.h
+++ b/drivers/net/nfp/nfp_common.h
@@ -16,9 +16,11 @@
 
 #define NFP_NET_PMD_VERSION "0.1"
 #define PCI_VENDOR_ID_NETRONOME         0x19ee
+#define PCI_DEVICE_ID_NFP3800_PF_NIC    0x3800
+#define PCI_DEVICE_ID_NFP3800_VF_NIC    0x3803
 #define PCI_DEVICE_ID_NFP4000_PF_NIC    0x4000
 #define PCI_DEVICE_ID_NFP6000_PF_NIC    0x6000
-#define PCI_DEVICE_ID_NFP6000_VF_NIC    0x6003
+#define PCI_DEVICE_ID_NFP6000_VF_NIC    0x6003  /* Include NFP4000VF */
 
 /* Forward declaration */
 struct nfp_net_adapter;
@@ -41,8 +43,16 @@ struct nfp_net_adapter;
 #define NFP_QCP_QUEUE_STS_HI                    0x000c
 #define NFP_QCP_QUEUE_STS_HI_WRITEPTR_mask    (0x3ffff)
 
+#define NFP_PCIE_QCP_NFP3800_OFFSET            0x400000
+#define NFP_PCIE_QCP_NFP6000_OFFSET            0x80000
+#define NFP_PCIE_QUEUE_NFP3800_MASK            0x1ff
+#define NFP_PCIE_QUEUE_NFP6000_MASK            0xff
+#define NFP_PCIE_QCP_PF_OFFSET                 0x0
+#define NFP_PCIE_QCP_VF_OFFSET                 0x0
+
 /* The offset of the queue controller queues in the PCIe Target */
-#define NFP_PCIE_QUEUE(_q) (0x80000 + (NFP_QCP_QUEUE_ADDR_SZ * ((_q) & 0xff)))
+#define NFP_PCIE_QUEUE(_offset, _q, _mask)    \
+               ((_offset) + (NFP_QCP_QUEUE_ADDR_SZ * ((_q) & (_mask))))
 
 /* Interrupt definitions */
 #define NFP_NET_IRQ_LSC_IDX             0
@@ -339,6 +349,25 @@ nfp_qcp_read(uint8_t *q, enum nfp_qcp_ptr ptr)
                return val & NFP_QCP_QUEUE_STS_HI_WRITEPTR_mask;
 }
 
+static inline uint32_t nfp_pci_queue(struct rte_pci_device *pdev, uint16_t 
queue)
+{
+       switch (pdev->id.device_id) {
+       case PCI_DEVICE_ID_NFP4000_PF_NIC:
+       case PCI_DEVICE_ID_NFP6000_PF_NIC:
+               return NFP_PCIE_QUEUE(NFP_PCIE_QCP_PF_OFFSET, queue,
+                               NFP_PCIE_QUEUE_NFP6000_MASK);
+       case PCI_DEVICE_ID_NFP3800_VF_NIC:
+               return NFP_PCIE_QUEUE(NFP_PCIE_QCP_VF_OFFSET, queue,
+                               NFP_PCIE_QUEUE_NFP3800_MASK);
+       case PCI_DEVICE_ID_NFP6000_VF_NIC:
+               return NFP_PCIE_QUEUE(NFP_PCIE_QCP_VF_OFFSET, queue,
+                               NFP_PCIE_QUEUE_NFP6000_MASK);
+       default:
+               return NFP_PCIE_QUEUE(NFP_PCIE_QCP_PF_OFFSET, queue,
+                               NFP_PCIE_QUEUE_NFP3800_MASK);
+       }
+}
+
 /* Prototypes for common NFP functions */
 int nfp_net_reconfig(struct nfp_net_hw *hw, uint32_t ctrl, uint32_t update);
 int nfp_net_configure(struct rte_eth_dev *dev);
diff --git a/drivers/net/nfp/nfp_ethdev.c b/drivers/net/nfp/nfp_ethdev.c
index 0d5caf94ea..4d2cd9b0b3 100644
--- a/drivers/net/nfp/nfp_ethdev.c
+++ b/drivers/net/nfp/nfp_ethdev.c
@@ -445,12 +445,13 @@ nfp_net_init(struct rte_eth_dev *eth_dev)
 
        /* Work out where in the BAR the queues start. */
        switch (pci_dev->id.device_id) {
+       case PCI_DEVICE_ID_NFP3800_PF_NIC:
        case PCI_DEVICE_ID_NFP4000_PF_NIC:
        case PCI_DEVICE_ID_NFP6000_PF_NIC:
                start_q = nn_cfg_readl(hw, NFP_NET_CFG_START_TXQ);
-               tx_bar_off = (uint64_t)start_q * NFP_QCP_QUEUE_ADDR_SZ;
+               tx_bar_off = nfp_pci_queue(pci_dev, start_q);
                start_q = nn_cfg_readl(hw, NFP_NET_CFG_START_RXQ);
-               rx_bar_off = (uint64_t)start_q * NFP_QCP_QUEUE_ADDR_SZ;
+               rx_bar_off = nfp_pci_queue(pci_dev, start_q);
                break;
        default:
                PMD_DRV_LOG(ERR, "nfp_net: no device ID matching");
@@ -763,6 +764,7 @@ nfp_pf_init(struct rte_pci_device *pci_dev)
 {
        int err;
        int ret = 0;
+       uint64_t addr;
        int total_ports;
        struct nfp_cpp *cpp;
        struct nfp_pf_dev *pf_dev;
@@ -866,8 +868,24 @@ nfp_pf_init(struct rte_pci_device *pci_dev)
        PMD_INIT_LOG(DEBUG, "ctrl bar: %p", pf_dev->ctrl_bar);
 
        /* configure access to tx/rx vNIC BARs */
+       switch (pci_dev->id.device_id) {
+       case PCI_DEVICE_ID_NFP3800_PF_NIC:
+               addr = NFP_PCIE_QUEUE(NFP_PCIE_QCP_NFP3800_OFFSET,
+                                       0, NFP_PCIE_QUEUE_NFP3800_MASK);
+               break;
+       case PCI_DEVICE_ID_NFP4000_PF_NIC:
+       case PCI_DEVICE_ID_NFP6000_PF_NIC:
+               addr = NFP_PCIE_QUEUE(NFP_PCIE_QCP_NFP6000_OFFSET,
+                                       0, NFP_PCIE_QUEUE_NFP6000_MASK);
+               break;
+       default:
+               PMD_INIT_LOG(ERR, "nfp_net: no device ID matching");
+               err = -ENODEV;
+               goto ctrl_area_cleanup;
+       }
+
        pf_dev->hw_queues = nfp_cpp_map_area(pf_dev->cpp, 0, 0,
-                       NFP_PCIE_QUEUE(0), NFP_QCP_QUEUE_AREA_SZ,
+                       addr, NFP_QCP_QUEUE_AREA_SZ,
                        &pf_dev->hwqueues_area);
        if (pf_dev->hw_queues == NULL) {
                PMD_INIT_LOG(ERR, "nfp_rtsym_map fails for net.qc");
@@ -994,6 +1012,10 @@ nfp_pf_pci_probe(struct rte_pci_driver *pci_drv 
__rte_unused,
 }
 
 static const struct rte_pci_id pci_id_nfp_pf_net_map[] = {
+       {
+               RTE_PCI_DEVICE(PCI_VENDOR_ID_NETRONOME,
+                              PCI_DEVICE_ID_NFP3800_PF_NIC)
+       },
        {
                RTE_PCI_DEVICE(PCI_VENDOR_ID_NETRONOME,
                               PCI_DEVICE_ID_NFP4000_PF_NIC)
diff --git a/drivers/net/nfp/nfp_ethdev_vf.c b/drivers/net/nfp/nfp_ethdev_vf.c
index 7d79a08041..f5a0406e7d 100644
--- a/drivers/net/nfp/nfp_ethdev_vf.c
+++ b/drivers/net/nfp/nfp_ethdev_vf.c
@@ -326,11 +326,12 @@ nfp_netvf_init(struct rte_eth_dev *eth_dev)
 
        /* Work out where in the BAR the queues start. */
        switch (pci_dev->id.device_id) {
+       case PCI_DEVICE_ID_NFP3800_VF_NIC:
        case PCI_DEVICE_ID_NFP6000_VF_NIC:
                start_q = nn_cfg_readl(hw, NFP_NET_CFG_START_TXQ);
-               tx_bar_off = (uint64_t)start_q * NFP_QCP_QUEUE_ADDR_SZ;
+               tx_bar_off = nfp_pci_queue(pci_dev, start_q);
                start_q = nn_cfg_readl(hw, NFP_NET_CFG_START_RXQ);
-               rx_bar_off = (uint64_t)start_q * NFP_QCP_QUEUE_ADDR_SZ;
+               rx_bar_off = nfp_pci_queue(pci_dev, start_q);
                break;
        default:
                PMD_DRV_LOG(ERR, "nfp_net: no device ID matching");
@@ -455,6 +456,10 @@ nfp_netvf_init(struct rte_eth_dev *eth_dev)
 }
 
 static const struct rte_pci_id pci_id_nfp_vf_net_map[] = {
+       {
+               RTE_PCI_DEVICE(PCI_VENDOR_ID_NETRONOME,
+                              PCI_DEVICE_ID_NFP3800_VF_NIC)
+       },
        {
                RTE_PCI_DEVICE(PCI_VENDOR_ID_NETRONOME,
                               PCI_DEVICE_ID_NFP6000_VF_NIC)
diff --git a/drivers/net/nfp/nfpcore/nfp_cpp.h 
b/drivers/net/nfp/nfpcore/nfp_cpp.h
index 720d3989e6..a04a68f546 100644
--- a/drivers/net/nfp/nfpcore/nfp_cpp.h
+++ b/drivers/net/nfp/nfpcore/nfp_cpp.h
@@ -214,7 +214,7 @@ void nfp_cpp_free(struct nfp_cpp *cpp);
  * @return             true if model is in the NFP6000 family, false otherwise.
  */
 #define NFP_CPP_MODEL_IS_6000(model)                \
-               ((NFP_CPP_MODEL_CHIP_of(model) >= 0x4000) && \
+               ((NFP_CPP_MODEL_CHIP_of(model) >= 0x3800) && \
                (NFP_CPP_MODEL_CHIP_of(model) < 0x7000))
 
 /*
diff --git a/drivers/net/nfp/nfpcore/nfp_nsp_eth.c 
b/drivers/net/nfp/nfpcore/nfp_nsp_eth.c
index 67946891ab..f8f3c372ac 100644
--- a/drivers/net/nfp/nfpcore/nfp_nsp_eth.c
+++ b/drivers/net/nfp/nfpcore/nfp_nsp_eth.c
@@ -266,6 +266,7 @@ __nfp_eth_read_ports(struct nfp_nsp *nsp)
        struct nfp_eth_table *table;
        uint32_t table_sz;
        int i, j, ret, cnt = 0;
+       const struct rte_ether_addr *mac;
 
        entries = malloc(NSP_ETH_TABLE_SIZE);
        if (!entries)
@@ -278,9 +279,15 @@ __nfp_eth_read_ports(struct nfp_nsp *nsp)
                goto err;
        }
 
-       for (i = 0; i < NSP_ETH_MAX_COUNT; i++)
-               if (entries[i].port & NSP_ETH_PORT_LANES_MASK)
+       /* The NFP3800 NIC support 8 ports, but only 2 ports are valid,
+        * the rest 6 ports mac are all 0, ensure we don't use these port
+        */
+       for (i = 0; i < NSP_ETH_MAX_COUNT; i++) {
+               mac = (const struct rte_ether_addr *)entries[i].mac_addr;
+               if ((entries[i].port & NSP_ETH_PORT_LANES_MASK) &&
+                               (!rte_is_zero_ether_addr(mac)))
                        cnt++;
+       }
 
        /* Some versions of flash will give us 0 instead of port count. For
         * those that give a port count, verify it against the value calculated
@@ -299,10 +306,13 @@ __nfp_eth_read_ports(struct nfp_nsp *nsp)
 
        memset(table, 0, table_sz);
        table->count = cnt;
-       for (i = 0, j = 0; i < NSP_ETH_MAX_COUNT; i++)
-               if (entries[i].port & NSP_ETH_PORT_LANES_MASK)
+       for (i = 0, j = 0; i < NSP_ETH_MAX_COUNT; i++) {
+               mac = (const struct rte_ether_addr *)entries[i].mac_addr;
+               if ((entries[i].port & NSP_ETH_PORT_LANES_MASK) &&
+                               (!rte_is_zero_ether_addr(mac)))
                        nfp_eth_port_translate(nsp, &entries[i], i,
-                                              &table->ports[j++]);
+                                       &table->ports[j++]);
+       }
 
        nfp_eth_calc_port_geometry(table);
        for (i = 0; i < (int)table->count; i++)
-- 
2.27.0

Reply via email to