summaryrefslogtreecommitdiffstats
path: root/dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch
diff options
context:
space:
mode:
authorDamjan Marion <damarion@cisco.com>2017-05-15 12:32:15 +0200
committerDamjan Marion <damarion@cisco.com>2017-05-15 12:32:15 +0200
commit572825df79e27a8baebcfc11d91bdb6f9776c2c7 (patch)
tree4dd0125068bc5fddae4e35015fea76b32a9fd3d1 /dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch
parentb5c13fdf470da1f4b0cfde151ba106cd84414e6b (diff)
dpdk: revert dpdk 17.05 change which causes virtio issues
This patch is causing DPDK to provide bad MAC address for legacy virtio interfaces. Change-Id: I526cd35a38164ede80a8ab6decb9e0d1ebfad723 Signed-off-by: Damjan Marion <damarion@cisco.com>
Diffstat (limited to 'dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch')
-rw-r--r--dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch122
1 files changed, 0 insertions, 122 deletions
diff --git a/dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch b/dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch
deleted file mode 100644
index e2965676a0a..00000000000
--- a/dpdk/dpdk-16.11_patches/0003-enic-fix-MAC-address-add-and-remove.patch
+++ /dev/null
@@ -1,122 +0,0 @@
-From 0cd0ed7b0b966704236e07fc1d3bd099deb407a7 Mon Sep 17 00:00:00 2001
-From: John Daley <johndale@cisco.com>
-Date: Tue, 31 Jan 2017 12:59:23 -0800
-Subject: [PATCH] The mac_addr_add callback function was simply replacing the
- primary MAC address instead of adding new ones and the mac_addr_remove
- callback would only remove the primary MAC form the adapter. Fix the
- functions to add or remove new address. Allow up to 64 MAC addresses per
- port.
-
-Signed-off-by: John Daley <johndale@cisco.com>
----
- drivers/net/enic/enic.h | 5 +++--
- drivers/net/enic/enic_ethdev.c | 6 +++---
- drivers/net/enic/enic_main.c | 21 ++++++++-------------
- 3 files changed, 14 insertions(+), 18 deletions(-)
-
-diff --git a/drivers/net/enic/enic.h b/drivers/net/enic/enic.h
-index 865cd76..5a807d4 100644
---- a/drivers/net/enic/enic.h
-+++ b/drivers/net/enic/enic.h
-@@ -60,6 +60,7 @@
- #define ENIC_RQ_MAX 16
- #define ENIC_CQ_MAX (ENIC_WQ_MAX + (ENIC_RQ_MAX / 2))
- #define ENIC_INTR_MAX (ENIC_CQ_MAX + 2)
-+#define ENIC_MAX_MAC_ADDR 64
-
- #define VLAN_ETH_HLEN 18
-
-@@ -277,8 +278,8 @@ extern void enic_dev_stats_get(struct enic *enic,
- struct rte_eth_stats *r_stats);
- extern void enic_dev_stats_clear(struct enic *enic);
- extern void enic_add_packet_filter(struct enic *enic);
--extern void enic_set_mac_address(struct enic *enic, uint8_t *mac_addr);
--extern void enic_del_mac_address(struct enic *enic);
-+void enic_set_mac_address(struct enic *enic, uint8_t *mac_addr);
-+void enic_del_mac_address(struct enic *enic, int mac_index);
- extern unsigned int enic_cleanup_wq(struct enic *enic, struct vnic_wq *wq);
- extern void enic_send_pkt(struct enic *enic, struct vnic_wq *wq,
- struct rte_mbuf *tx_pkt, unsigned short len,
-diff --git a/drivers/net/enic/enic_ethdev.c b/drivers/net/enic/enic_ethdev.c
-index 2b154ec..d2d04a9 100644
---- a/drivers/net/enic/enic_ethdev.c
-+++ b/drivers/net/enic/enic_ethdev.c
-@@ -464,7 +464,7 @@ static void enicpmd_dev_info_get(struct rte_eth_dev *eth_dev,
- device_info->max_tx_queues = enic->conf_wq_count;
- device_info->min_rx_bufsize = ENIC_MIN_MTU;
- device_info->max_rx_pktlen = enic->max_mtu + ETHER_HDR_LEN + 4;
-- device_info->max_mac_addrs = 1;
-+ device_info->max_mac_addrs = ENIC_MAX_MAC_ADDR;
- device_info->rx_offload_capa =
- DEV_RX_OFFLOAD_VLAN_STRIP |
- DEV_RX_OFFLOAD_IPV4_CKSUM |
-@@ -545,12 +545,12 @@ static void enicpmd_add_mac_addr(struct rte_eth_dev *eth_dev,
- enic_set_mac_address(enic, mac_addr->addr_bytes);
- }
-
--static void enicpmd_remove_mac_addr(struct rte_eth_dev *eth_dev, __rte_unused uint32_t index)
-+static void enicpmd_remove_mac_addr(struct rte_eth_dev *eth_dev, uint32_t index)
- {
- struct enic *enic = pmd_priv(eth_dev);
-
- ENICPMD_FUNC_TRACE();
-- enic_del_mac_address(enic);
-+ enic_del_mac_address(enic, index);
- }
-
- static int enicpmd_mtu_set(struct rte_eth_dev *eth_dev, uint16_t mtu)
-diff --git a/drivers/net/enic/enic_main.c b/drivers/net/enic/enic_main.c
-index f0b15ac..21e8ede 100644
---- a/drivers/net/enic/enic_main.c
-+++ b/drivers/net/enic/enic_main.c
-@@ -190,9 +190,12 @@ void enic_dev_stats_get(struct enic *enic, struct rte_eth_stats *r_stats)
- r_stats->rx_nombuf = rte_atomic64_read(&soft_stats->rx_nombuf);
- }
-
--void enic_del_mac_address(struct enic *enic)
-+void enic_del_mac_address(struct enic *enic, int mac_index)
- {
-- if (vnic_dev_del_addr(enic->vdev, enic->mac_addr))
-+ struct rte_eth_dev *eth_dev = enic->rte_dev;
-+ uint8_t *mac_addr = eth_dev->data->mac_addrs[mac_index].addr_bytes;
-+
-+ if (vnic_dev_del_addr(enic->vdev, mac_addr))
- dev_err(enic, "del mac addr failed\n");
- }
-
-@@ -205,15 +208,6 @@ void enic_set_mac_address(struct enic *enic, uint8_t *mac_addr)
- return;
- }
-
-- err = vnic_dev_del_addr(enic->vdev, enic->mac_addr);
-- if (err) {
-- dev_err(enic, "del mac addr failed\n");
-- return;
-- }
--
-- ether_addr_copy((struct ether_addr *)mac_addr,
-- (struct ether_addr *)enic->mac_addr);
--
- err = vnic_dev_add_addr(enic->vdev, mac_addr);
- if (err) {
- dev_err(enic, "add mac addr failed\n");
-@@ -1308,13 +1302,14 @@ static int enic_dev_init(struct enic *enic)
- /* Get the supported filters */
- enic_fdir_info(enic);
-
-- eth_dev->data->mac_addrs = rte_zmalloc("enic_mac_addr", ETH_ALEN, 0);
-+ eth_dev->data->mac_addrs = rte_zmalloc("enic_mac_addr", ETH_ALEN
-+ * ENIC_MAX_MAC_ADDR, 0);
- if (!eth_dev->data->mac_addrs) {
- dev_err(enic, "mac addr storage alloc failed, aborting.\n");
- return -1;
- }
- ether_addr_copy((struct ether_addr *) enic->mac_addr,
-- &eth_dev->data->mac_addrs[0]);
-+ eth_dev->data->mac_addrs);
-
- vnic_dev_set_reset_flag(enic->vdev, 0);
-
---
-1.9.1
-