]> git.droids-corp.org - dpdk.git/commitdiff
mempool: fix stack handler dequeue
authorOlivier Matz <olivier.matz@6wind.com>
Mon, 23 Jan 2017 17:11:03 +0000 (18:11 +0100)
committerThomas Monjalon <thomas.monjalon@6wind.com>
Sun, 29 Jan 2017 22:38:33 +0000 (23:38 +0100)
The return value of the stack handler is wrong: it should be 0 on
success, not the number of objects dequeued.

This could lead to memory leaks depending on how the caller checks the
return value (ret < 0 or ret != 0). This was also breaking autotests
with debug enabled, because the debug cookies are only updated when the
function returns 0, so the cookies were not updated, leading to
an abort().

Fixes: 295a530b0844 ("mempool: add stack mempool handler")
Cc: stable@dpdk.org
Signed-off-by: Olivier Matz <olivier.matz@6wind.com>
lib/librte_mempool/rte_mempool_stack.c

index 5fd8af24e012e3643315f1ba86d0f9fc75895e1a..817f77e6657ca1ba7342fb6331458cc7f68ce4e5 100644 (file)
@@ -118,7 +118,7 @@ stack_dequeue(struct rte_mempool *mp, void **obj_table,
 
        s->len -= n;
        rte_spinlock_unlock(&s->sl);
-       return n;
+       return 0;
 }
 
 static unsigned