mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-20 23:38:21 +07:00
net/mlx5e: Correctly handle RSS indirection table when changing number of channels
Upon changing num_channels, reset the RSS indirection table to
match the new value.
Fixes: 2d75b2bc8a
('net/mlx5e: Add ethtool RSS configuration options')
Signed-off-by: Tariq Toukan <tariqt@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
bdfc028de1
commit
85082dba0a
@ -619,6 +619,8 @@ void mlx5e_build_tir_ctx_hash(void *tirc, struct mlx5e_priv *priv);
|
|||||||
|
|
||||||
int mlx5e_open_locked(struct net_device *netdev);
|
int mlx5e_open_locked(struct net_device *netdev);
|
||||||
int mlx5e_close_locked(struct net_device *netdev);
|
int mlx5e_close_locked(struct net_device *netdev);
|
||||||
|
void mlx5e_build_default_indir_rqt(u32 *indirection_rqt, int len,
|
||||||
|
int num_channels);
|
||||||
|
|
||||||
static inline void mlx5e_tx_notify_hw(struct mlx5e_sq *sq,
|
static inline void mlx5e_tx_notify_hw(struct mlx5e_sq *sq,
|
||||||
struct mlx5e_tx_wqe *wqe, int bf_sz)
|
struct mlx5e_tx_wqe *wqe, int bf_sz)
|
||||||
|
@ -385,6 +385,8 @@ static int mlx5e_set_channels(struct net_device *dev,
|
|||||||
mlx5e_close_locked(dev);
|
mlx5e_close_locked(dev);
|
||||||
|
|
||||||
priv->params.num_channels = count;
|
priv->params.num_channels = count;
|
||||||
|
mlx5e_build_default_indir_rqt(priv->params.indirection_rqt,
|
||||||
|
MLX5E_INDIR_RQT_SIZE, count);
|
||||||
|
|
||||||
if (was_opened)
|
if (was_opened)
|
||||||
err = mlx5e_open_locked(dev);
|
err = mlx5e_open_locked(dev);
|
||||||
|
@ -1199,7 +1199,6 @@ static void mlx5e_fill_indir_rqt_rqns(struct mlx5e_priv *priv, void *rqtc)
|
|||||||
ix = mlx5e_bits_invert(i, MLX5E_LOG_INDIR_RQT_SIZE);
|
ix = mlx5e_bits_invert(i, MLX5E_LOG_INDIR_RQT_SIZE);
|
||||||
|
|
||||||
ix = priv->params.indirection_rqt[ix];
|
ix = priv->params.indirection_rqt[ix];
|
||||||
ix = ix % priv->params.num_channels;
|
|
||||||
MLX5_SET(rqtc, rqtc, rq_num[i],
|
MLX5_SET(rqtc, rqtc, rq_num[i],
|
||||||
test_bit(MLX5E_STATE_OPENED, &priv->state) ?
|
test_bit(MLX5E_STATE_OPENED, &priv->state) ?
|
||||||
priv->channel[ix]->rq.rqn :
|
priv->channel[ix]->rq.rqn :
|
||||||
@ -2101,12 +2100,20 @@ u16 mlx5e_get_max_inline_cap(struct mlx5_core_dev *mdev)
|
|||||||
2 /*sizeof(mlx5e_tx_wqe.inline_hdr_start)*/;
|
2 /*sizeof(mlx5e_tx_wqe.inline_hdr_start)*/;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void mlx5e_build_default_indir_rqt(u32 *indirection_rqt, int len,
|
||||||
|
int num_channels)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < len; i++)
|
||||||
|
indirection_rqt[i] = i % num_channels;
|
||||||
|
}
|
||||||
|
|
||||||
static void mlx5e_build_netdev_priv(struct mlx5_core_dev *mdev,
|
static void mlx5e_build_netdev_priv(struct mlx5_core_dev *mdev,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
int num_channels)
|
int num_channels)
|
||||||
{
|
{
|
||||||
struct mlx5e_priv *priv = netdev_priv(netdev);
|
struct mlx5e_priv *priv = netdev_priv(netdev);
|
||||||
int i;
|
|
||||||
|
|
||||||
priv->params.log_sq_size =
|
priv->params.log_sq_size =
|
||||||
MLX5E_PARAMS_DEFAULT_LOG_SQ_SIZE;
|
MLX5E_PARAMS_DEFAULT_LOG_SQ_SIZE;
|
||||||
@ -2130,8 +2137,8 @@ static void mlx5e_build_netdev_priv(struct mlx5_core_dev *mdev,
|
|||||||
netdev_rss_key_fill(priv->params.toeplitz_hash_key,
|
netdev_rss_key_fill(priv->params.toeplitz_hash_key,
|
||||||
sizeof(priv->params.toeplitz_hash_key));
|
sizeof(priv->params.toeplitz_hash_key));
|
||||||
|
|
||||||
for (i = 0; i < MLX5E_INDIR_RQT_SIZE; i++)
|
mlx5e_build_default_indir_rqt(priv->params.indirection_rqt,
|
||||||
priv->params.indirection_rqt[i] = i % num_channels;
|
MLX5E_INDIR_RQT_SIZE, num_channels);
|
||||||
|
|
||||||
priv->params.lro_wqe_sz =
|
priv->params.lro_wqe_sz =
|
||||||
MLX5E_PARAMS_DEFAULT_LRO_WQE_SZ;
|
MLX5E_PARAMS_DEFAULT_LRO_WQE_SZ;
|
||||||
|
Loading…
Reference in New Issue
Block a user