eal: add tailq safe iterator macro
authorPablo de Lara <pablo.de.lara.guarch@intel.com>
Fri, 22 Jul 2016 14:02:01 +0000 (15:02 +0100)
committerThomas Monjalon <thomas.monjalon@6wind.com>
Fri, 22 Jul 2016 15:38:59 +0000 (17:38 +0200)
Removing/freeing elements elements within a TAILQ_FOREACH loop is not safe.
FreeBSD defines TAILQ_FOREACH_SAFE macro, which permits
these operations safely.
This patch defines this macro for Linux systems, where it is not defined.

Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
lib/librte_eal/common/include/rte_tailq.h

index 4a686e6..cc3c0f1 100644 (file)
@@ -155,6 +155,14 @@ void __attribute__((constructor, used)) tailqinitfn_ ##t(void) \
                rte_panic("Cannot initialize tailq: %s\n", t.name); \
 }
 
+/* This macro permits both remove and free var within the loop safely.*/
+#ifndef TAILQ_FOREACH_SAFE
+#define TAILQ_FOREACH_SAFE(var, head, field, tvar)             \
+       for ((var) = TAILQ_FIRST((head));                       \
+           (var) && ((tvar) = TAILQ_NEXT((var), field), 1);    \
+           (var) = (tvar))
+#endif
+
 #ifdef __cplusplus
 }
 #endif