net/mlx5: Fix the order of fc_stats cleanup
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>
This commit is contained in:
parent
3c140dd54f
commit
b1b9f97a09
|
@ -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,
|
||||
|
|
Loading…
Reference in New Issue