|
@@ -50,6 +50,19 @@ struct list_head {
|
|
|
&pos->member != (head); \
|
|
|
pos = list_entry(pos->member.next, typeof(*pos), member))
|
|
|
|
|
|
+/**
|
|
|
+ * list_for_each_entry_safe - iterate over list of given type safe against removal of list entry
|
|
|
+ * @pos: the type * to use as a loop cursor.
|
|
|
+ * @n: another type * to use as temporary storage
|
|
|
+ * @head: the head for your list.
|
|
|
+ * @member: the name of the list_struct within the struct.
|
|
|
+ */
|
|
|
+#define list_for_each_entry_safe(pos, n, head, member) \
|
|
|
+ for (pos = list_entry((head)->next, typeof(*pos), member), \
|
|
|
+ n = list_entry(pos->member.next, typeof(*pos), member); \
|
|
|
+ &pos->member != (head); \
|
|
|
+ pos = n, n = list_entry(n->member.next, typeof(*n), member))
|
|
|
+
|
|
|
/**
|
|
|
* list_empty - tests whether a list is empty
|
|
|
* @head: the list to test.
|