diff options
Diffstat (limited to 'common/dpdk/recipes-extended/dpdk/dpdk/dpdk-dev-v3-14-18-net-axgbe-add-promiscuous-mode-support.patch')
-rw-r--r-- | common/dpdk/recipes-extended/dpdk/dpdk/dpdk-dev-v3-14-18-net-axgbe-add-promiscuous-mode-support.patch | 120 |
1 files changed, 0 insertions, 120 deletions
diff --git a/common/dpdk/recipes-extended/dpdk/dpdk/dpdk-dev-v3-14-18-net-axgbe-add-promiscuous-mode-support.patch b/common/dpdk/recipes-extended/dpdk/dpdk/dpdk-dev-v3-14-18-net-axgbe-add-promiscuous-mode-support.patch deleted file mode 100644 index 025780e5..00000000 --- a/common/dpdk/recipes-extended/dpdk/dpdk/dpdk-dev-v3-14-18-net-axgbe-add-promiscuous-mode-support.patch +++ /dev/null @@ -1,120 +0,0 @@ -From patchwork Fri Mar 9 08:42:30 2018 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [dpdk-dev,v3,14/18] net/axgbe: add promiscuous mode support -From: Ravi Kumar <ravi1.kumar@amd.com> -X-Patchwork-Id: 35833 -X-Patchwork-Delegate: ferruh.yigit@intel.com -Message-Id: <1520584954-130575-14-git-send-email-Ravi1.kumar@amd.com> -List-Id: dev.dpdk.org -To: dev@dpdk.org -Cc: ferruh.yigit@intel.com -Date: Fri, 9 Mar 2018 03:42:30 -0500 - -Signed-off-by: Ravi Kumar <Ravi1.kumar@amd.com> ---- - doc/guides/nics/axgbe.rst | 2 ++ - doc/guides/nics/features/axgbe.ini | 2 ++ - drivers/net/axgbe/axgbe_ethdev.c | 48 ++++++++++++++++++++++++++++++++++++++ - 3 files changed, 52 insertions(+) - -diff --git a/doc/guides/nics/axgbe.rst b/doc/guides/nics/axgbe.rst -index e9bebb8..8fe75bf 100644 ---- a/doc/guides/nics/axgbe.rst -+++ b/doc/guides/nics/axgbe.rst -@@ -135,6 +135,8 @@ AXGBE PMD has support for: - - - Base L2 features - - TSS (Transmit Side Scaling) -+- Promiscuous mode -+- Multicast mode - - RSS (Receive Side Scaling) - - Checksum offload - - Jumbo Frame upto 9K -diff --git a/doc/guides/nics/features/axgbe.ini b/doc/guides/nics/features/axgbe.ini -index 2dbff18..9f4d38f 100644 ---- a/doc/guides/nics/features/axgbe.ini -+++ b/doc/guides/nics/features/axgbe.ini -@@ -7,6 +7,8 @@ - Speed capabilities = Y - Link status = Y - Jumbo frame = Y -+Promiscuous mode = Y -+Allmulticast mode = Y - RSS hash = Y - CRC offload = Y - L3 checksum offload = Y -diff --git a/drivers/net/axgbe/axgbe_ethdev.c b/drivers/net/axgbe/axgbe_ethdev.c -index ebae6cc..0b67cf6 100644 ---- a/drivers/net/axgbe/axgbe_ethdev.c -+++ b/drivers/net/axgbe/axgbe_ethdev.c -@@ -137,6 +137,10 @@ static int axgbe_dev_start(struct rte_eth_dev *dev); - static void axgbe_dev_stop(struct rte_eth_dev *dev); - static void axgbe_dev_interrupt_handler(void *param); - static void axgbe_dev_close(struct rte_eth_dev *dev); -+static void axgbe_dev_promiscuous_enable(struct rte_eth_dev *dev); -+static void axgbe_dev_promiscuous_disable(struct rte_eth_dev *dev); -+static void axgbe_dev_allmulticast_enable(struct rte_eth_dev *dev); -+static void axgbe_dev_allmulticast_disable(struct rte_eth_dev *dev); - static int axgbe_dev_link_update(struct rte_eth_dev *dev, - int wait_to_complete); - static void axgbe_dev_info_get(struct rte_eth_dev *dev, -@@ -195,6 +199,10 @@ static const struct eth_dev_ops axgbe_eth_dev_ops = { - .dev_start = axgbe_dev_start, - .dev_stop = axgbe_dev_stop, - .dev_close = axgbe_dev_close, -+ .promiscuous_enable = axgbe_dev_promiscuous_enable, -+ .promiscuous_disable = axgbe_dev_promiscuous_disable, -+ .allmulticast_enable = axgbe_dev_allmulticast_enable, -+ .allmulticast_disable = axgbe_dev_allmulticast_disable, - .link_update = axgbe_dev_link_update, - .dev_infos_get = axgbe_dev_info_get, - .rx_queue_setup = axgbe_dev_rx_queue_setup, -@@ -341,6 +349,46 @@ axgbe_dev_close(struct rte_eth_dev *dev) - axgbe_dev_clear_queues(dev); - } - -+static void -+axgbe_dev_promiscuous_enable(struct rte_eth_dev *dev) -+{ -+ PMD_INIT_FUNC_TRACE(); -+ struct axgbe_port *pdata = dev->data->dev_private; -+ -+ AXGMAC_IOWRITE_BITS(pdata, MAC_PFR, PR, 1); -+} -+ -+static void -+axgbe_dev_promiscuous_disable(struct rte_eth_dev *dev) -+{ -+ PMD_INIT_FUNC_TRACE(); -+ struct axgbe_port *pdata = dev->data->dev_private; -+ -+ AXGMAC_IOWRITE_BITS(pdata, MAC_PFR, PR, 0); -+} -+ -+static void -+axgbe_dev_allmulticast_enable(struct rte_eth_dev *dev) -+{ -+ PMD_INIT_FUNC_TRACE(); -+ struct axgbe_port *pdata = dev->data->dev_private; -+ -+ if (AXGMAC_IOREAD_BITS(pdata, MAC_PFR, PM)) -+ return; -+ AXGMAC_IOWRITE_BITS(pdata, MAC_PFR, PM, 1); -+} -+ -+static void -+axgbe_dev_allmulticast_disable(struct rte_eth_dev *dev) -+{ -+ PMD_INIT_FUNC_TRACE(); -+ struct axgbe_port *pdata = dev->data->dev_private; -+ -+ if (!AXGMAC_IOREAD_BITS(pdata, MAC_PFR, PM)) -+ return; -+ AXGMAC_IOWRITE_BITS(pdata, MAC_PFR, PM, 0); -+} -+ - /* return 0 means link status changed, -1 means not changed */ - static int - axgbe_dev_link_update(struct rte_eth_dev *dev, |