X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=drivers%2Fnet%2Fmlx5%2Fmlx5_ethdev.c;h=7631f644b24ada506371f8dd3d96289e11bd916b;hb=952ebacce4f2;hp=6b4efcdcea4839ad3108fffe524e4b477f2a58a3;hpb=1256805dd54d3e0debd95c0420ca7f211bb9407c;p=dpdk.git diff --git a/drivers/net/mlx5/mlx5_ethdev.c b/drivers/net/mlx5/mlx5_ethdev.c index 6b4efcdcea..7631f644b2 100644 --- a/drivers/net/mlx5/mlx5_ethdev.c +++ b/drivers/net/mlx5/mlx5_ethdev.c @@ -21,6 +21,8 @@ #include #include +#include + #include "mlx5_rxtx.h" #include "mlx5_autoconf.h" @@ -41,7 +43,7 @@ mlx5_ifindex(const struct rte_eth_dev *dev) MLX5_ASSERT(priv); MLX5_ASSERT(priv->if_index); - ifindex = priv->if_index; + ifindex = priv->bond_ifindex > 0 ? priv->bond_ifindex : priv->if_index; if (!ifindex) rte_errno = ENXIO; return ifindex; @@ -75,8 +77,8 @@ mlx5_dev_configure(struct rte_eth_dev *dev) return -rte_errno; } priv->rss_conf.rss_key = - rte_realloc(priv->rss_conf.rss_key, - MLX5_RSS_HASH_KEY_LEN, 0); + mlx5_realloc(priv->rss_conf.rss_key, MLX5_MEM_RTE, + MLX5_RSS_HASH_KEY_LEN, 0, SOCKET_ID_ANY); if (!priv->rss_conf.rss_key) { DRV_LOG(ERR, "port %u cannot allocate RSS hash key memory (%u)", dev->data->port_id, rxqs_n); @@ -142,7 +144,8 @@ mlx5_dev_configure_rss_reta(struct rte_eth_dev *dev) if (priv->skip_default_rss_reta) return ret; - rss_queue_arr = rte_malloc("", rxqs_n * sizeof(unsigned int), 0); + rss_queue_arr = mlx5_malloc(0, rxqs_n * sizeof(unsigned int), 0, + SOCKET_ID_ANY); if (!rss_queue_arr) { DRV_LOG(ERR, "port %u cannot allocate RSS queue list (%u)", dev->data->port_id, rxqs_n); @@ -163,7 +166,7 @@ mlx5_dev_configure_rss_reta(struct rte_eth_dev *dev) DRV_LOG(ERR, "port %u cannot handle this many Rx queues (%u)", dev->data->port_id, rss_queue_n); rte_errno = EINVAL; - rte_free(rss_queue_arr); + mlx5_free(rss_queue_arr); return -rte_errno; } DRV_LOG(INFO, "port %u Rx queues number update: %u -> %u", @@ -179,7 +182,7 @@ mlx5_dev_configure_rss_reta(struct rte_eth_dev *dev) rss_queue_n)); ret = mlx5_rss_reta_index_resize(dev, reta_idx_n); if (ret) { - rte_free(rss_queue_arr); + mlx5_free(rss_queue_arr); return ret; } /* @@ -192,7 +195,7 @@ mlx5_dev_configure_rss_reta(struct rte_eth_dev *dev) if (++j == rss_queue_n) j = 0; } - rte_free(rss_queue_arr); + mlx5_free(rss_queue_arr); return ret; } @@ -566,12 +569,12 @@ mlx5_dev_to_eswitch_info(struct rte_eth_dev *dev) * 0 on success, a negative errno value otherwise and rte_errno is set. */ int -mlx5_hairpin_cap_get(struct rte_eth_dev *dev, - struct rte_eth_hairpin_cap *cap) +mlx5_hairpin_cap_get(struct rte_eth_dev *dev, struct rte_eth_hairpin_cap *cap) { struct mlx5_priv *priv = dev->data->dev_private; + struct mlx5_dev_config *config = &priv->config; - if (priv->sh->devx == 0) { + if (!priv->sh->devx || !config->dest_tir || !config->dv_flow_en) { rte_errno = ENOTSUP; return -rte_errno; }