f-stack/dpdk/drivers/net/mlx5/mlx5_rxmode.c

171 lines
3.6 KiB
C
Raw Normal View History

2019-06-25 11:12:58 +00:00
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright 2015 6WIND S.A.
* Copyright 2015 Mellanox Technologies, Ltd
2017-04-21 10:43:26 +00:00
*/
#include <stddef.h>
#include <errno.h>
#include <string.h>
/* Verbs header. */
/* ISO C doesn't support unnamed structs/unions, disabling -pedantic. */
#ifdef PEDANTIC
#pragma GCC diagnostic ignored "-Wpedantic"
#endif
#include <infiniband/verbs.h>
#ifdef PEDANTIC
#pragma GCC diagnostic error "-Wpedantic"
#endif
2019-06-25 11:12:58 +00:00
#include <rte_ethdev_driver.h>
2017-04-21 10:43:26 +00:00
#include "mlx5.h"
#include "mlx5_rxtx.h"
#include "mlx5_utils.h"
/**
* DPDK callback to enable promiscuous mode.
*
* @param dev
* Pointer to Ethernet device structure.
2020-06-18 16:55:50 +00:00
*
* @return
* 0 on success, a negative errno value otherwise and rte_errno is set.
2017-04-21 10:43:26 +00:00
*/
2020-06-18 16:55:50 +00:00
int
2017-04-21 10:43:26 +00:00
mlx5_promiscuous_enable(struct rte_eth_dev *dev)
{
2019-06-26 10:17:41 +00:00
struct mlx5_priv *priv = dev->data->dev_private;
2018-11-21 08:34:11 +00:00
int ret;
dev->data->promiscuous = 1;
2018-11-21 08:34:11 +00:00
if (priv->isolated) {
DRV_LOG(WARNING,
"port %u cannot enable promiscuous mode"
" in flow isolation mode",
dev->data->port_id);
2020-06-18 16:55:50 +00:00
return 0;
}
if (priv->config.vf) {
ret = mlx5_nl_promisc(dev, 1);
if (ret)
return ret;
2018-11-21 08:34:11 +00:00
}
ret = mlx5_traffic_restart(dev);
if (ret)
DRV_LOG(ERR, "port %u cannot enable promiscuous mode: %s",
dev->data->port_id, strerror(rte_errno));
2020-06-18 16:55:50 +00:00
/*
* rte_eth_dev_promiscuous_enable() rollback
* dev->data->promiscuous in the case of failure.
*/
return ret;
2017-04-21 10:43:26 +00:00
}
/**
* DPDK callback to disable promiscuous mode.
*
* @param dev
* Pointer to Ethernet device structure.
2020-06-18 16:55:50 +00:00
*
* @return
* 0 on success, a negative errno value otherwise and rte_errno is set.
2017-04-21 10:43:26 +00:00
*/
2020-06-18 16:55:50 +00:00
int
2017-04-21 10:43:26 +00:00
mlx5_promiscuous_disable(struct rte_eth_dev *dev)
{
2019-06-26 10:17:41 +00:00
struct mlx5_priv *priv = dev->data->dev_private;
2018-11-21 08:34:11 +00:00
int ret;
dev->data->promiscuous = 0;
2020-06-18 16:55:50 +00:00
if (priv->config.vf) {
ret = mlx5_nl_promisc(dev, 0);
if (ret)
return ret;
}
2018-11-21 08:34:11 +00:00
ret = mlx5_traffic_restart(dev);
if (ret)
DRV_LOG(ERR, "port %u cannot disable promiscuous mode: %s",
dev->data->port_id, strerror(rte_errno));
2020-06-18 16:55:50 +00:00
/*
* rte_eth_dev_promiscuous_disable() rollback
* dev->data->promiscuous in the case of failure.
*/
return ret;
2017-04-21 10:43:26 +00:00
}
/**
* DPDK callback to enable allmulti mode.
*
* @param dev
* Pointer to Ethernet device structure.
2020-06-18 16:55:50 +00:00
*
* @return
* 0 on success, a negative errno value otherwise and rte_errno is set.
2017-04-21 10:43:26 +00:00
*/
2020-06-18 16:55:50 +00:00
int
2017-04-21 10:43:26 +00:00
mlx5_allmulticast_enable(struct rte_eth_dev *dev)
{
2019-06-26 10:17:41 +00:00
struct mlx5_priv *priv = dev->data->dev_private;
2018-11-21 08:34:11 +00:00
int ret;
dev->data->all_multicast = 1;
2018-11-21 08:34:11 +00:00
if (priv->isolated) {
DRV_LOG(WARNING,
"port %u cannot enable allmulticast mode"
" in flow isolation mode",
dev->data->port_id);
2020-06-18 16:55:50 +00:00
return 0;
}
if (priv->config.vf) {
ret = mlx5_nl_allmulti(dev, 1);
if (ret)
goto error;
2018-11-21 08:34:11 +00:00
}
ret = mlx5_traffic_restart(dev);
if (ret)
DRV_LOG(ERR, "port %u cannot enable allmulicast mode: %s",
dev->data->port_id, strerror(rte_errno));
2020-06-18 16:55:50 +00:00
error:
/*
* rte_eth_allmulticast_enable() rollback
* dev->data->all_multicast in the case of failure.
*/
return ret;
2017-04-21 10:43:26 +00:00
}
/**
* DPDK callback to disable allmulti mode.
*
* @param dev
* Pointer to Ethernet device structure.
2020-06-18 16:55:50 +00:00
*
* @return
* 0 on success, a negative errno value otherwise and rte_errno is set.
2017-04-21 10:43:26 +00:00
*/
2020-06-18 16:55:50 +00:00
int
2017-04-21 10:43:26 +00:00
mlx5_allmulticast_disable(struct rte_eth_dev *dev)
{
2019-06-26 10:17:41 +00:00
struct mlx5_priv *priv = dev->data->dev_private;
2018-11-21 08:34:11 +00:00
int ret;
dev->data->all_multicast = 0;
2020-06-18 16:55:50 +00:00
if (priv->config.vf) {
ret = mlx5_nl_allmulti(dev, 0);
if (ret)
goto error;
}
2018-11-21 08:34:11 +00:00
ret = mlx5_traffic_restart(dev);
if (ret)
DRV_LOG(ERR, "port %u cannot disable allmulicast mode: %s",
dev->data->port_id, strerror(rte_errno));
2020-06-18 16:55:50 +00:00
error:
/*
* rte_eth_allmulticast_disable() rollback
* dev->data->all_multicast in the case of failure.
*/
return ret;
2017-04-21 10:43:26 +00:00
}