mlxsw: spectrum_span: On policer_id_base_ref_count, use dec_and_test
authorPetr Machata <petrm@mellanox.com>
Mon, 3 Aug 2020 16:11:36 +0000 (19:11 +0300)
committerDavid S. Miller <davem@davemloft.net>
Tue, 4 Aug 2020 01:06:46 +0000 (18:06 -0700)
When unsetting policer base, the SPAN code currently uses refcount_dec().
However that function splats when the counter reaches zero, because
reaching zero without actually testing is in general indicative of a
missing cleanup. There is no cleanup to be done here, but nonetheless, use
refcount_dec_and_test() as required.

Signed-off-by: Petr Machata <petrm@mellanox.com>
Reviewed-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlxsw/spectrum_span.c

index 323eaf9..5c959a9 100644 (file)
@@ -837,7 +837,8 @@ static int mlxsw_sp_span_policer_id_base_set(struct mlxsw_sp_span *span,
 
 static void mlxsw_sp_span_policer_id_base_unset(struct mlxsw_sp_span *span)
 {
-       refcount_dec(&span->policer_id_base_ref_count);
+       if (refcount_dec_and_test(&span->policer_id_base_ref_count))
+               span->policer_id_base = 0;
 }
 
 static struct mlxsw_sp_span_entry *