git.droids-corp.org
/
dpdk.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
net/virtio: allocate vrings on device NUMA node
[dpdk.git]
/
drivers
/
net
/
mlx5
/
mlx5_rxmode.c
diff --git
a/drivers/net/mlx5/mlx5_rxmode.c
b/drivers/net/mlx5/mlx5_rxmode.c
index
0c1e9eb
..
e74fdef
100644
(file)
--- a/
drivers/net/mlx5/mlx5_rxmode.c
+++ b/
drivers/net/mlx5/mlx5_rxmode.c
@@
-1,6
+1,6
@@
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright 2015 6WIND S.A.
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright 2015 6WIND S.A.
- * Copyright 2015 Mellanox
.
+ * Copyright 2015 Mellanox
Technologies, Ltd
*/
#include <stddef.h>
*/
#include <stddef.h>
@@
-32,13
+32,23
@@
void
mlx5_promiscuous_enable(struct rte_eth_dev *dev)
{
void
mlx5_promiscuous_enable(struct rte_eth_dev *dev)
{
+ struct priv *priv = dev->data->dev_private;
int ret;
dev->data->promiscuous = 1;
int ret;
dev->data->promiscuous = 1;
+ if (priv->isolated) {
+ DRV_LOG(WARNING,
+ "port %u cannot enable promiscuous mode"
+ " in flow isolation mode",
+ dev->data->port_id);
+ return;
+ }
+ if (priv->config.vf)
+ mlx5_nl_promisc(dev, 1);
ret = mlx5_traffic_restart(dev);
if (ret)
ret = mlx5_traffic_restart(dev);
if (ret)
-
ERROR("%p cannot enable promiscuous mode: %s", (void *)dev
,
- strerror(rte_errno));
+
DRV_LOG(ERR, "port %u cannot enable promiscuous mode: %s"
,
+
dev->data->port_id,
strerror(rte_errno));
}
/**
}
/**
@@
-50,13
+60,16
@@
mlx5_promiscuous_enable(struct rte_eth_dev *dev)
void
mlx5_promiscuous_disable(struct rte_eth_dev *dev)
{
void
mlx5_promiscuous_disable(struct rte_eth_dev *dev)
{
+ struct priv *priv = dev->data->dev_private;
int ret;
dev->data->promiscuous = 0;
int ret;
dev->data->promiscuous = 0;
+ if (priv->config.vf)
+ mlx5_nl_promisc(dev, 0);
ret = mlx5_traffic_restart(dev);
if (ret)
ret = mlx5_traffic_restart(dev);
if (ret)
-
ERROR("%p cannot disable promiscuous mode: %s", (void *)dev
,
- strerror(rte_errno));
+
DRV_LOG(ERR, "port %u cannot disable promiscuous mode: %s"
,
+
dev->data->port_id,
strerror(rte_errno));
}
/**
}
/**
@@
-68,13
+81,23
@@
mlx5_promiscuous_disable(struct rte_eth_dev *dev)
void
mlx5_allmulticast_enable(struct rte_eth_dev *dev)
{
void
mlx5_allmulticast_enable(struct rte_eth_dev *dev)
{
+ struct priv *priv = dev->data->dev_private;
int ret;
dev->data->all_multicast = 1;
int ret;
dev->data->all_multicast = 1;
+ if (priv->isolated) {
+ DRV_LOG(WARNING,
+ "port %u cannot enable allmulticast mode"
+ " in flow isolation mode",
+ dev->data->port_id);
+ return;
+ }
+ if (priv->config.vf)
+ mlx5_nl_allmulti(dev, 1);
ret = mlx5_traffic_restart(dev);
if (ret)
ret = mlx5_traffic_restart(dev);
if (ret)
-
ERROR("%p cannot enable allmulicast mode: %s", (void *)dev
,
- strerror(rte_errno));
+
DRV_LOG(ERR, "port %u cannot enable allmulicast mode: %s"
,
+
dev->data->port_id,
strerror(rte_errno));
}
/**
}
/**
@@
-86,11
+109,14
@@
mlx5_allmulticast_enable(struct rte_eth_dev *dev)
void
mlx5_allmulticast_disable(struct rte_eth_dev *dev)
{
void
mlx5_allmulticast_disable(struct rte_eth_dev *dev)
{
+ struct priv *priv = dev->data->dev_private;
int ret;
dev->data->all_multicast = 0;
int ret;
dev->data->all_multicast = 0;
+ if (priv->config.vf)
+ mlx5_nl_allmulti(dev, 0);
ret = mlx5_traffic_restart(dev);
if (ret)
ret = mlx5_traffic_restart(dev);
if (ret)
-
ERROR("%p cannot disable allmulicast mode: %s", (void *)dev
,
- strerror(rte_errno));
+
DRV_LOG(ERR, "port %u cannot disable allmulicast mode: %s"
,
+
dev->data->port_id,
strerror(rte_errno));
}
}