net/mlx5: E-Switch, Fix default encap mode
Encap mode is related to switchdev mode only. Move the init of
the encap mode to eswitch_offloads. Before this change, we reported
that eswitch supports encap, even tough the device was in non
SRIOV mode.
Fixes: 7768d1971d
('net/mlx5: E-Switch, Add control for encapsulation')
Signed-off-by: Maor Gottlieb <maorg@mellanox.com>
Reviewed-by: Roi Dayan <roid@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
This commit is contained in:
parent
e858faf556
commit
9a64144d68
@ -1882,11 +1882,6 @@ int mlx5_eswitch_init(struct mlx5_core_dev *dev)
|
|||||||
esw->enabled_vports = 0;
|
esw->enabled_vports = 0;
|
||||||
esw->mode = SRIOV_NONE;
|
esw->mode = SRIOV_NONE;
|
||||||
esw->offloads.inline_mode = MLX5_INLINE_MODE_NONE;
|
esw->offloads.inline_mode = MLX5_INLINE_MODE_NONE;
|
||||||
if (MLX5_CAP_ESW_FLOWTABLE_FDB(dev, reformat) &&
|
|
||||||
MLX5_CAP_ESW_FLOWTABLE_FDB(dev, decap))
|
|
||||||
esw->offloads.encap = DEVLINK_ESWITCH_ENCAP_MODE_BASIC;
|
|
||||||
else
|
|
||||||
esw->offloads.encap = DEVLINK_ESWITCH_ENCAP_MODE_NONE;
|
|
||||||
|
|
||||||
dev->priv.eswitch = esw;
|
dev->priv.eswitch = esw;
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1840,6 +1840,12 @@ int esw_offloads_init(struct mlx5_eswitch *esw, int vf_nvports,
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
|
if (MLX5_CAP_ESW_FLOWTABLE_FDB(esw->dev, reformat) &&
|
||||||
|
MLX5_CAP_ESW_FLOWTABLE_FDB(esw->dev, decap))
|
||||||
|
esw->offloads.encap = DEVLINK_ESWITCH_ENCAP_MODE_BASIC;
|
||||||
|
else
|
||||||
|
esw->offloads.encap = DEVLINK_ESWITCH_ENCAP_MODE_NONE;
|
||||||
|
|
||||||
err = esw_offloads_steering_init(esw, vf_nvports, total_nvports);
|
err = esw_offloads_steering_init(esw, vf_nvports, total_nvports);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
@ -1901,6 +1907,7 @@ void esw_offloads_cleanup(struct mlx5_eswitch *esw)
|
|||||||
esw_offloads_devcom_cleanup(esw);
|
esw_offloads_devcom_cleanup(esw);
|
||||||
esw_offloads_unload_all_reps(esw, num_vfs);
|
esw_offloads_unload_all_reps(esw, num_vfs);
|
||||||
esw_offloads_steering_cleanup(esw);
|
esw_offloads_steering_cleanup(esw);
|
||||||
|
esw->offloads.encap = DEVLINK_ESWITCH_ENCAP_MODE_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int esw_mode_from_devlink(u16 mode, u16 *mlx5_mode)
|
static int esw_mode_from_devlink(u16 mode, u16 *mlx5_mode)
|
||||||
|
Loading…
Reference in New Issue
Block a user