Dan Carpenter <dan.carpenter@xxxxxxxxxx> writes: > The mlxsw_sp2_nve_vxlan_learning_set() function is supposed to return > zero on success or negative error codes. So it needs to be type int > instead of bool. Yes. Vast majority of the time the error code is 0, which converts to false, which converts back to 0. But for errors this gets sliced to 1, which eventually percolates to notifier_from_errno(), which yields NOTIFY_STOP_MASK | NOTIFY_DONE instead of encoding the error code, masking the failure. > Fixes: 4ee70efab68d ("mlxsw: spectrum_nve: Add support for VXLAN on Spectrum-2") > Signed-off-by: Dan Carpenter <dan.carpenter@xxxxxxxxxx> Reviewed-by: Petr Machata <petrm@xxxxxxxxxx> Thanks! > --- > drivers/net/ethernet/mellanox/mlxsw/spectrum_nve_vxlan.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/net/ethernet/mellanox/mlxsw/spectrum_nve_vxlan.c b/drivers/net/ethernet/mellanox/mlxsw/spectrum_nve_vxlan.c > index bb8eeb86edf7..52c2fe3644d4 100644 > --- a/drivers/net/ethernet/mellanox/mlxsw/spectrum_nve_vxlan.c > +++ b/drivers/net/ethernet/mellanox/mlxsw/spectrum_nve_vxlan.c > @@ -310,8 +310,8 @@ const struct mlxsw_sp_nve_ops mlxsw_sp1_nve_vxlan_ops = { > .fdb_clear_offload = mlxsw_sp_nve_vxlan_clear_offload, > }; > > -static bool mlxsw_sp2_nve_vxlan_learning_set(struct mlxsw_sp *mlxsw_sp, > - bool learning_en) > +static int mlxsw_sp2_nve_vxlan_learning_set(struct mlxsw_sp *mlxsw_sp, > + bool learning_en) > { > char tnpc_pl[MLXSW_REG_TNPC_LEN];