net/dpaa: support MAC address update
authorShreyansh Jain <shreyansh.jain@nxp.com>
Thu, 28 Sep 2017 12:29:51 +0000 (17:59 +0530)
committerFerruh Yigit <ferruh.yigit@intel.com>
Fri, 6 Oct 2017 00:49:50 +0000 (02:49 +0200)
Signed-off-by: Hemant Agrawal <hemant.agrawal@nxp.com>
Signed-off-by: Shreyansh Jain <shreyansh.jain@nxp.com>
doc/guides/nics/features/dpaa.ini
drivers/net/dpaa/dpaa_ethdev.c

index f21a85f..cdf5e46 100644 (file)
@@ -10,5 +10,6 @@ Jumbo frame          = Y
 MTU update           = Y
 Promiscuous mode     = Y
 Allmulticast mode    = Y
 MTU update           = Y
 Promiscuous mode     = Y
 Allmulticast mode    = Y
+Unicast MAC filter   = Y
 ARMv8                = Y
 Usage doc            = Y
 ARMv8                = Y
 Usage doc            = Y
index f45ed5e..893e7f5 100644 (file)
@@ -310,6 +310,50 @@ static int dpaa_link_up(struct rte_eth_dev *dev)
        return 0;
 }
 
        return 0;
 }
 
+static int
+dpaa_dev_add_mac_addr(struct rte_eth_dev *dev,
+                            struct ether_addr *addr,
+                            uint32_t index,
+                            __rte_unused uint32_t pool)
+{
+       int ret;
+       struct dpaa_if *dpaa_intf = dev->data->dev_private;
+
+       PMD_INIT_FUNC_TRACE();
+
+       ret = fman_if_add_mac_addr(dpaa_intf->fif, addr->addr_bytes, index);
+
+       if (ret)
+               RTE_LOG(ERR, PMD, "error: Adding the MAC ADDR failed:"
+                       " err = %d", ret);
+       return 0;
+}
+
+static void
+dpaa_dev_remove_mac_addr(struct rte_eth_dev *dev,
+                         uint32_t index)
+{
+       struct dpaa_if *dpaa_intf = dev->data->dev_private;
+
+       PMD_INIT_FUNC_TRACE();
+
+       fman_if_clear_mac_addr(dpaa_intf->fif, index);
+}
+
+static void
+dpaa_dev_set_mac_addr(struct rte_eth_dev *dev,
+                      struct ether_addr *addr)
+{
+       int ret;
+       struct dpaa_if *dpaa_intf = dev->data->dev_private;
+
+       PMD_INIT_FUNC_TRACE();
+
+       ret = fman_if_add_mac_addr(dpaa_intf->fif, addr->addr_bytes, 0);
+       if (ret)
+               RTE_LOG(ERR, PMD, "error: Setting the MAC ADDR failed %d", ret);
+}
+
 static struct eth_dev_ops dpaa_devops = {
        .dev_configure            = dpaa_eth_dev_configure,
        .dev_start                = dpaa_eth_dev_start,
 static struct eth_dev_ops dpaa_devops = {
        .dev_configure            = dpaa_eth_dev_configure,
        .dev_start                = dpaa_eth_dev_start,
@@ -330,6 +374,10 @@ static struct eth_dev_ops dpaa_devops = {
        .mtu_set                  = dpaa_mtu_set,
        .dev_set_link_down        = dpaa_link_down,
        .dev_set_link_up          = dpaa_link_up,
        .mtu_set                  = dpaa_mtu_set,
        .dev_set_link_down        = dpaa_link_down,
        .dev_set_link_up          = dpaa_link_up,
+       .mac_addr_add             = dpaa_dev_add_mac_addr,
+       .mac_addr_remove          = dpaa_dev_remove_mac_addr,
+       .mac_addr_set             = dpaa_dev_set_mac_addr,
+
 };
 
 /* Initialise an Rx FQ */
 };
 
 /* Initialise an Rx FQ */