mempool: fix unsafe removal from list by callback
If a mempool is removed from the list by a callback function during rte_mempool_walk(), the TAILQ_FOREACH loop will fail unexpectedly. It is fixed by using the safe version of the loop macro. Reported-by: Sergio Gonzalez Monroy <sergio.gonzalez.monroy@intel.com> Signed-off-by: Thomas Monjalon <thomas.monjalon@6wind.com> Acked-by: Olivier Matz <olivier.matz@6wind.com>
This commit is contained in:
parent
3cb6bdc761
commit
cae54ac47c
@ -1283,12 +1283,13 @@ void rte_mempool_walk(void (*func)(struct rte_mempool *, void *),
|
||||
{
|
||||
struct rte_tailq_entry *te = NULL;
|
||||
struct rte_mempool_list *mempool_list;
|
||||
void *tmp_te;
|
||||
|
||||
mempool_list = RTE_TAILQ_CAST(rte_mempool_tailq.head, rte_mempool_list);
|
||||
|
||||
rte_rwlock_read_lock(RTE_EAL_MEMPOOL_RWLOCK);
|
||||
|
||||
TAILQ_FOREACH(te, mempool_list, next) {
|
||||
TAILQ_FOREACH_SAFE(te, mempool_list, next, tmp_te) {
|
||||
(*func)((struct rte_mempool *) te->data, arg);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user