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;
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
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;
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
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;
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
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;
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
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
|
|
|
}
|