> From: wushao...@chinatelecom.cn [mailto:wushao...@chinatelecom.cn]
> Sent: Sunday, 1 January 2023 06.18
> 
> From: Shaohua Wu <wushao...@chinatelecom.cn>
> 
> rte_mempool_dump add dump for monitoring available and
> used memory blocks
> 
> Signed-off-by: Shaohua Wu <wushao...@chinatelecom.cn>
> ---
>  lib/mempool/rte_mempool.c | 5 +++++
>  1 file changed, 5 insertions(+)
> 
> diff --git a/lib/mempool/rte_mempool.c b/lib/mempool/rte_mempool.c
> index f33f455790..09d512a604 100644
> --- a/lib/mempool/rte_mempool.c
> +++ b/lib/mempool/rte_mempool.c
> @@ -1265,9 +1265,14 @@ rte_mempool_dump(FILE *f, struct rte_mempool
> *mp)
> 
>       cache_count = rte_mempool_dump_cache(f, mp);
>       common_count = rte_mempool_ops_get_count(mp);
> +
>       if ((cache_count + common_count) > mp->size)
>               common_count = mp->size - cache_count;
>       fprintf(f, "  common_pool_count=%u\n", common_count);
> +     fprintf(f, "  common_pool_avail_count=%u\n",
> +                             rte_mempool_avail_count(mp));

The number of available objects in the common pool is already shown as 
"common_pool_count".

If you want to show the total number of available objects in both the common 
pool and the caches, you can calculate is as common_count + cache_count, 
instead of calling rte_mempool_avail_count(). And "total_count" would be a 
better name than "common_pool_avail_count".

> +     fprintf(f, "  common_pool_used_count=%u\n",
> +                             rte_mempool_in_use_count(mp));

common_pool_used_count can be calculated as mp->size - common_count, instead of 
calling rte_mempool_in_use_count(mp).

> 
>       /* sum and dump statistics */
>  #ifdef RTE_LIBRTE_MEMPOOL_STATS
> --
> 2.30.2
> 

Reply via email to