Signed-off-by: Radu Nicolau <[email protected]>
---
drivers/net/bonding/rte_eth_bond_8023ad.c | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/drivers/net/bonding/rte_eth_bond_8023ad.c
b/drivers/net/bonding/rte_eth_bond_8023ad.c
index f8cea4b..730087f 100644
--- a/drivers/net/bonding/rte_eth_bond_8023ad.c
+++ b/drivers/net/bonding/rte_eth_bond_8023ad.c
@@ -917,7 +917,7 @@ bond_mode_8023ad_activate_slave(struct rte_eth_dev
*bond_dev,
};
char mem_name[RTE_ETH_NAME_MAX_LEN];
- int socket_id;
+ int socket_id, ret;
unsigned element_size;
uint32_t total_tx_desc;
struct bond_tx_queue *bd_tx_q;
@@ -942,7 +942,12 @@ bond_mode_8023ad_activate_slave(struct rte_eth_dev
*bond_dev,
/* use this port as agregator */
port->aggregator_port_id = slave_id;
- rte_eth_promiscuous_enable(slave_id);
+
+ /* try to enable multicast, if fail set promiscuous */
+ rte_eth_allmulticast_enable(slave_id);
+ ret = rte_eth_allmulticast_get(slave_id);
+ if (ret != 1)
+ rte_eth_promiscuous_enable(slave_id);
timer_cancel(&port->warning_timer);
--
2.7.5