forked from luck/tmp_suning_uos_patched
net/mlx5e: Fix access to non-existing receive queue
In case number of channels is changed while interface is down, RSS indirection table is mistakenly not modified accordingly, causing access to out-of-range non-existing object. Fix by updating the RSS indireciton table also in the early return flow of interface down. Fixes:fb35c534b7
("net/mlx5e: Fix NULL pointer derefernce in set channels error flow") Fixes:bbeb53b8b2
("net/mlx5e: Move RSS params to a dedicated struct") Reported-by: Or Gerlitz <ogerlitz@mellanox.com> Tested-by: Maria Pasechnik <mariap@mellanox.com> Signed-off-by: Tariq Toukan <tariqt@mellanox.com> Reviewed-by: Eran Ben Elisha <eranbe@mellanox.com> Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
This commit is contained in:
parent
3d6f3cdf9b
commit
c475e11e82
|
@ -424,6 +424,9 @@ int mlx5e_ethtool_set_channels(struct mlx5e_priv *priv,
|
||||||
|
|
||||||
if (!test_bit(MLX5E_STATE_OPENED, &priv->state)) {
|
if (!test_bit(MLX5E_STATE_OPENED, &priv->state)) {
|
||||||
priv->channels.params = new_channels.params;
|
priv->channels.params = new_channels.params;
|
||||||
|
if (!netif_is_rxfh_configured(priv->netdev))
|
||||||
|
mlx5e_build_default_indir_rqt(priv->rss_params.indirection_rqt,
|
||||||
|
MLX5E_INDIR_RQT_SIZE, count);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user