net/mlx5: Fix the order of fc_stats cleanup
authorGavi Teitz <gavi@mellanox.com>
Sun, 11 Aug 2019 06:21:20 +0000 (09:21 +0300)
committerSaeed Mahameed <saeedm@mellanox.com>
Tue, 20 Aug 2019 20:08:19 +0000 (13:08 -0700)
Previously, mlx5_cleanup_fc_stats() would cleanup the flow counter
pool beofre releasing all the counters to it, which would result in
flow counter bulks not getting freed. Resolve this by changing the
order in which elements of fc_stats are cleaned up, so that the flow
counter pool is cleaned up after all the counters are released.

Also move cleanup actions for freeing the bulk query memory and
destroying the idr to the end of mlx5_cleanup_fc_stats().

Signed-off-by: Gavi Teitz <gavi@mellanox.com>
Reviewed-by: Roi Dayan <roid@mellanox.com>
Reviewed-by: Vlad Buslov <vladbu@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
drivers/net/ethernet/mellanox/mlx5/core/fs_counters.c

index 1804cf3c3814e72755da2847b888f40bc3b32e98..ab69effb056d83b36c8cad9ea37c6eeef853e3b7 100644 (file)
@@ -402,21 +402,20 @@ void mlx5_cleanup_fc_stats(struct mlx5_core_dev *dev)
        struct mlx5_fc *counter;
        struct mlx5_fc *tmp;
 
-       mlx5_fc_pool_cleanup(&fc_stats->fc_pool);
        cancel_delayed_work_sync(&dev->priv.fc_stats.work);
        destroy_workqueue(dev->priv.fc_stats.wq);
        dev->priv.fc_stats.wq = NULL;
 
-       kfree(fc_stats->bulk_query_out);
-
-       idr_destroy(&fc_stats->counters_idr);
-
        tmplist = llist_del_all(&fc_stats->addlist);
        llist_for_each_entry_safe(counter, tmp, tmplist, addlist)
                mlx5_fc_release(dev, counter);
 
        list_for_each_entry_safe(counter, tmp, &fc_stats->counters, list)
                mlx5_fc_release(dev, counter);
+
+       mlx5_fc_pool_cleanup(&fc_stats->fc_pool);
+       idr_destroy(&fc_stats->counters_idr);
+       kfree(fc_stats->bulk_query_out);
 }
 
 int mlx5_fc_query(struct mlx5_core_dev *dev, struct mlx5_fc *counter,