On 8/9/2020 11:22 AM, Sarosh Arif wrote:
rte_mempool_get_bulk is used to get bufs/many_bufs from the pool,
but at some locations when test fails the bufs/many_bufs are
not returned back to the pool.
Due to this, multiple executions of distributor_autotest gives the
following error message: Error getting mbufs from pool.
To resolve this issue rte_mempool_put_bulk is used whenever the test
fails and returns.

Signed-off-by: Sarosh Arif <sarosh.a...@emumba.com>
---
v2:
remove double freeing of mbufs
v3:
resubmit to run the tests again
---
}

--snip--

Looks good to me. Even though I could not repeat the conditions to cause one of these errors, the additons make sense.

In my testing, I did add in several rte_mempool_avail_count() checks to see if there were leakages, and all the mempool counts were stable, but that was due to the fixes in the patch set from Lukasz : http://patches.dpdk.org/project/dpdk/list/?series=12442

However, if there are situations where packets are not returned from workers, this should clean them up nicely before returning.

Reviewed-by: David Hunt <david.h...@intel.com>




Reply via email to