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/mlx5: support yellow meter action for hierarchy tag rule
[dpdk.git]
/
drivers
/
net
/
mlx5
/
mlx5_mac.c
diff --git
a/drivers/net/mlx5/mlx5_mac.c
b/drivers/net/mlx5/mlx5_mac.c
index
2d808d6
..
a791fed
100644
(file)
--- a/
drivers/net/mlx5/mlx5_mac.c
+++ b/
drivers/net/mlx5/mlx5_mac.c
@@
-8,12
+8,9
@@
#include <string.h>
#include <inttypes.h>
#include <errno.h>
#include <string.h>
#include <inttypes.h>
#include <errno.h>
-#include <netinet/in.h>
-#include <sys/ioctl.h>
-#include <arpa/inet.h>
#include <rte_ether.h>
#include <rte_ether.h>
-#include <
rte_
ethdev_driver.h>
+#include <ethdev_driver.h>
#include <rte_common.h>
#include "mlx5_defs.h"
#include <rte_common.h>
#include "mlx5_defs.h"
@@
-156,20
+153,30
@@
mlx5_mac_addr_set(struct rte_eth_dev *dev, struct rte_ether_addr *mac_addr)
{
uint16_t port_id;
struct mlx5_priv *priv = dev->data->dev_private;
{
uint16_t port_id;
struct mlx5_priv *priv = dev->data->dev_private;
+ struct mlx5_priv *pf_priv;
- /* Configuring the VF instead of its representor. */
- if (priv->representor) {
+ /*
+ * Configuring the VF instead of its representor,
+ * need to skip the special case of HPF on Bluefield.
+ */
+ if (priv->representor && !mlx5_is_hpf(dev) && !mlx5_is_sf_repr(dev)) {
DRV_LOG(DEBUG, "VF represented by port %u setting primary MAC address",
dev->data->port_id);
DRV_LOG(DEBUG, "VF represented by port %u setting primary MAC address",
dev->data->port_id);
+ if (priv->pf_bond >= 0) {
+ /* Bonding, get owner PF ifindex from shared data. */
+ return mlx5_os_vf_mac_addr_modify
+ (priv,
+ priv->sh->bond.ports[priv->pf_bond].ifindex,
+ mac_addr,
+ MLX5_REPRESENTOR_REPR(priv->representor_id));
+ }
RTE_ETH_FOREACH_DEV_SIBLING(port_id, dev->data->port_id) {
RTE_ETH_FOREACH_DEV_SIBLING(port_id, dev->data->port_id) {
- priv = rte_eth_devices[port_id].data->dev_private;
- if (priv->master == 1) {
- priv = dev->data->dev_private;
+ pf_priv = rte_eth_devices[port_id].data->dev_private;
+ if (pf_priv->master == 1)
return mlx5_os_vf_mac_addr_modify
return mlx5_os_vf_mac_addr_modify
- (priv,
- mlx5_ifindex(&rte_eth_devices[port_id]),
- mac_addr, priv->representor_id);
- }
+ (priv, pf_priv->if_index, mac_addr,
+ MLX5_REPRESENTOR_REPR
+ (priv->representor_id));
}
rte_errno = -ENOTSUP;
return rte_errno;
}
rte_errno = -ENOTSUP;
return rte_errno;