On 08/31/2018 06:53 PM, Andrew Rybchenko wrote:
From: Evgeny Im <evgeny...@oktetlabs.com>

Signed-off-by: Evgeny Im <evgeny...@oktetlabs.com>
Signed-off-by: Andrew Rybchenko <arybche...@solarflare.com>

<...>


diff --git a/drivers/net/failsafe/failsafe_ops.c 
b/drivers/net/failsafe/failsafe_ops.c
index 24e91c931..2583cff58 100644
--- a/drivers/net/failsafe/failsafe_ops.c
+++ b/drivers/net/failsafe/failsafe_ops.c
@@ -952,6 +952,53 @@ fs_mac_addr_set(struct rte_eth_dev *dev, struct ether_addr 
*mac_addr)
        return 0;
  }
+static int
+fs_set_mc_addr_list(struct rte_eth_dev *dev,
+                   struct ether_addr *mc_addr_set, uint32_t nb_mc_addr)
+{
+       struct sub_device *sdev;
+       uint8_t i;
+       int ret;
+
+       fs_lock(dev, 0);
+       FOREACH_SUBDEV_STATE(sdev, i, dev, DEV_ACTIVE) {
+               ret = rte_eth_dev_set_mc_addr_list(PORT_ID(sdev),
+                                                  mc_addr_set, nb_mc_addr);
+               if (ret != 0) {
+                       ERROR("Operation rte_eth_dev_set_mc_addr_list failed for 
sub_device %d with error %d",
+                             i, ret);
+                       goto rollback;
+               }
+       }
+       /* Do not reallocate/save if the method is called from sync */
+       if (mc_addr_set != PRIV(dev)->mcast_addrs) {
+               void *mcast_addrs = rte_realloc(PRIV(dev)->mcast_addrs,
+                       nb_mc_addr * sizeof(PRIV(dev)->mcast_addrs[0]), 0);
+               if (mcast_addrs == NULL) {
+                       ret = -ENOMEM;

Self-NACK since it fails for empty list set since rte_realloc() returns NULL.
Will fix in v2.

+                       goto rollback;
+               }
+               PRIV(dev)->mcast_addrs = mcast_addrs;
+               rte_memcpy(PRIV(dev)->mcast_addrs, mc_addr_set,
+                          nb_mc_addr * sizeof(PRIV(dev)->mcast_addrs[0]));
+       }
+       PRIV(dev)->nb_mcast_addr = nb_mc_addr;
+       fs_unlock(dev, 0);
+       return 0;
+
+rollback:
+       FOREACH_SUBDEV_STATE(sdev, i, dev, DEV_ACTIVE) {
+               int rc = rte_eth_dev_set_mc_addr_list(PORT_ID(sdev),
+                       PRIV(dev)->mcast_addrs,      PRIV(dev)->nb_mcast_addr);
+               if (rc != 0) {
+                       ERROR("Multicast MAC address list rollback for sub_device %d 
failed with error %d",
+                             i, rc);
+               }
+       }
+       fs_unlock(dev, 0);
+       return ret;
+}
+
  static int
  fs_rss_hash_update(struct rte_eth_dev *dev,
                        struct rte_eth_rss_conf *rss_conf)

<...>

Reply via email to