]> git.kernelconcepts.de Git - karo-tx-linux.git/blob - include/linux/list.h
mtd: nand: complain loudly when chip->bits_per_cell is not correctly initialized
[karo-tx-linux.git] / include / linux / list.h
1 #ifndef _LINUX_LIST_H
2 #define _LINUX_LIST_H
3
4 #include <linux/types.h>
5 #include <linux/stddef.h>
6 #include <linux/poison.h>
7 #include <linux/const.h>
8 #include <linux/kernel.h>
9
10 /*
11  * Simple doubly linked list implementation.
12  *
13  * Some of the internal functions ("__xxx") are useful when
14  * manipulating whole lists rather than single entries, as
15  * sometimes we already know the next/prev entries and we can
16  * generate better code by using them directly rather than
17  * using the generic single-entry routines.
18  */
19
20 #define LIST_HEAD_INIT(name) { &(name), &(name) }
21
22 #define LIST_HEAD(name) \
23         struct list_head name = LIST_HEAD_INIT(name)
24
25 static inline void INIT_LIST_HEAD(struct list_head *list)
26 {
27         WRITE_ONCE(list->next, list);
28         list->prev = list;
29 }
30
31 #ifdef CONFIG_DEBUG_LIST
32 extern bool __list_add_valid(struct list_head *new,
33                               struct list_head *prev,
34                               struct list_head *next);
35 extern bool __list_del_entry_valid(struct list_head *entry);
36 #else
37 static inline bool __list_add_valid(struct list_head *new,
38                                 struct list_head *prev,
39                                 struct list_head *next)
40 {
41         return true;
42 }
43 static inline bool __list_del_entry_valid(struct list_head *entry)
44 {
45         return true;
46 }
47 #endif
48
49 /*
50  * Insert a new entry between two known consecutive entries.
51  *
52  * This is only for internal list manipulation where we know
53  * the prev/next entries already!
54  */
55 static inline void __list_add(struct list_head *new,
56                               struct list_head *prev,
57                               struct list_head *next)
58 {
59         if (!__list_add_valid(new, prev, next))
60                 return;
61
62         next->prev = new;
63         new->next = next;
64         new->prev = prev;
65         WRITE_ONCE(prev->next, new);
66 }
67
68 /**
69  * list_add - add a new entry
70  * @new: new entry to be added
71  * @head: list head to add it after
72  *
73  * Insert a new entry after the specified head.
74  * This is good for implementing stacks.
75  */
76 static inline void list_add(struct list_head *new, struct list_head *head)
77 {
78         __list_add(new, head, head->next);
79 }
80
81
82 /**
83  * list_add_tail - add a new entry
84  * @new: new entry to be added
85  * @head: list head to add it before
86  *
87  * Insert a new entry before the specified head.
88  * This is useful for implementing queues.
89  */
90 static inline void list_add_tail(struct list_head *new, struct list_head *head)
91 {
92         __list_add(new, head->prev, head);
93 }
94
95 /*
96  * Delete a list entry by making the prev/next entries
97  * point to each other.
98  *
99  * This is only for internal list manipulation where we know
100  * the prev/next entries already!
101  */
102 static inline void __list_del(struct list_head * prev, struct list_head * next)
103 {
104         next->prev = prev;
105         WRITE_ONCE(prev->next, next);
106 }
107
108 /**
109  * list_del - deletes entry from list.
110  * @entry: the element to delete from the list.
111  * Note: list_empty() on entry does not return true after this, the entry is
112  * in an undefined state.
113  */
114 static inline void __list_del_entry(struct list_head *entry)
115 {
116         if (!__list_del_entry_valid(entry))
117                 return;
118
119         __list_del(entry->prev, entry->next);
120 }
121
122 static inline void list_del(struct list_head *entry)
123 {
124         __list_del_entry(entry);
125         entry->next = LIST_POISON1;
126         entry->prev = LIST_POISON2;
127 }
128
129 /**
130  * list_replace - replace old entry by new one
131  * @old : the element to be replaced
132  * @new : the new element to insert
133  *
134  * If @old was empty, it will be overwritten.
135  */
136 static inline void list_replace(struct list_head *old,
137                                 struct list_head *new)
138 {
139         new->next = old->next;
140         new->next->prev = new;
141         new->prev = old->prev;
142         new->prev->next = new;
143 }
144
145 static inline void list_replace_init(struct list_head *old,
146                                         struct list_head *new)
147 {
148         list_replace(old, new);
149         INIT_LIST_HEAD(old);
150 }
151
152 /**
153  * list_del_init - deletes entry from list and reinitialize it.
154  * @entry: the element to delete from the list.
155  */
156 static inline void list_del_init(struct list_head *entry)
157 {
158         __list_del_entry(entry);
159         INIT_LIST_HEAD(entry);
160 }
161
162 /**
163  * list_move - delete from one list and add as another's head
164  * @list: the entry to move
165  * @head: the head that will precede our entry
166  */
167 static inline void list_move(struct list_head *list, struct list_head *head)
168 {
169         __list_del_entry(list);
170         list_add(list, head);
171 }
172
173 /**
174  * list_move_tail - delete from one list and add as another's tail
175  * @list: the entry to move
176  * @head: the head that will follow our entry
177  */
178 static inline void list_move_tail(struct list_head *list,
179                                   struct list_head *head)
180 {
181         __list_del_entry(list);
182         list_add_tail(list, head);
183 }
184
185 /**
186  * list_is_last - tests whether @list is the last entry in list @head
187  * @list: the entry to test
188  * @head: the head of the list
189  */
190 static inline int list_is_last(const struct list_head *list,
191                                 const struct list_head *head)
192 {
193         return list->next == head;
194 }
195
196 /**
197  * list_empty - tests whether a list is empty
198  * @head: the list to test.
199  */
200 static inline int list_empty(const struct list_head *head)
201 {
202         return READ_ONCE(head->next) == head;
203 }
204
205 /**
206  * list_empty_careful - tests whether a list is empty and not being modified
207  * @head: the list to test
208  *
209  * Description:
210  * tests whether a list is empty _and_ checks that no other CPU might be
211  * in the process of modifying either member (next or prev)
212  *
213  * NOTE: using list_empty_careful() without synchronization
214  * can only be safe if the only activity that can happen
215  * to the list entry is list_del_init(). Eg. it cannot be used
216  * if another CPU could re-list_add() it.
217  */
218 static inline int list_empty_careful(const struct list_head *head)
219 {
220         struct list_head *next = head->next;
221         return (next == head) && (next == head->prev);
222 }
223
224 /**
225  * list_rotate_left - rotate the list to the left
226  * @head: the head of the list
227  */
228 static inline void list_rotate_left(struct list_head *head)
229 {
230         struct list_head *first;
231
232         if (!list_empty(head)) {
233                 first = head->next;
234                 list_move_tail(first, head);
235         }
236 }
237
238 /**
239  * list_is_singular - tests whether a list has just one entry.
240  * @head: the list to test.
241  */
242 static inline int list_is_singular(const struct list_head *head)
243 {
244         return !list_empty(head) && (head->next == head->prev);
245 }
246
247 static inline void __list_cut_position(struct list_head *list,
248                 struct list_head *head, struct list_head *entry)
249 {
250         struct list_head *new_first = entry->next;
251         list->next = head->next;
252         list->next->prev = list;
253         list->prev = entry;
254         entry->next = list;
255         head->next = new_first;
256         new_first->prev = head;
257 }
258
259 /**
260  * list_cut_position - cut a list into two
261  * @list: a new list to add all removed entries
262  * @head: a list with entries
263  * @entry: an entry within head, could be the head itself
264  *      and if so we won't cut the list
265  *
266  * This helper moves the initial part of @head, up to and
267  * including @entry, from @head to @list. You should
268  * pass on @entry an element you know is on @head. @list
269  * should be an empty list or a list you do not care about
270  * losing its data.
271  *
272  */
273 static inline void list_cut_position(struct list_head *list,
274                 struct list_head *head, struct list_head *entry)
275 {
276         if (list_empty(head))
277                 return;
278         if (list_is_singular(head) &&
279                 (head->next != entry && head != entry))
280                 return;
281         if (entry == head)
282                 INIT_LIST_HEAD(list);
283         else
284                 __list_cut_position(list, head, entry);
285 }
286
287 static inline void __list_splice(const struct list_head *list,
288                                  struct list_head *prev,
289                                  struct list_head *next)
290 {
291         struct list_head *first = list->next;
292         struct list_head *last = list->prev;
293
294         first->prev = prev;
295         prev->next = first;
296
297         last->next = next;
298         next->prev = last;
299 }
300
301 /**
302  * list_splice - join two lists, this is designed for stacks
303  * @list: the new list to add.
304  * @head: the place to add it in the first list.
305  */
306 static inline void list_splice(const struct list_head *list,
307                                 struct list_head *head)
308 {
309         if (!list_empty(list))
310                 __list_splice(list, head, head->next);
311 }
312
313 /**
314  * list_splice_tail - join two lists, each list being a queue
315  * @list: the new list to add.
316  * @head: the place to add it in the first list.
317  */
318 static inline void list_splice_tail(struct list_head *list,
319                                 struct list_head *head)
320 {
321         if (!list_empty(list))
322                 __list_splice(list, head->prev, head);
323 }
324
325 /**
326  * list_splice_init - join two lists and reinitialise the emptied list.
327  * @list: the new list to add.
328  * @head: the place to add it in the first list.
329  *
330  * The list at @list is reinitialised
331  */
332 static inline void list_splice_init(struct list_head *list,
333                                     struct list_head *head)
334 {
335         if (!list_empty(list)) {
336                 __list_splice(list, head, head->next);
337                 INIT_LIST_HEAD(list);
338         }
339 }
340
341 /**
342  * list_splice_tail_init - join two lists and reinitialise the emptied list
343  * @list: the new list to add.
344  * @head: the place to add it in the first list.
345  *
346  * Each of the lists is a queue.
347  * The list at @list is reinitialised
348  */
349 static inline void list_splice_tail_init(struct list_head *list,
350                                          struct list_head *head)
351 {
352         if (!list_empty(list)) {
353                 __list_splice(list, head->prev, head);
354                 INIT_LIST_HEAD(list);
355         }
356 }
357
358 /**
359  * list_entry - get the struct for this entry
360  * @ptr:        the &struct list_head pointer.
361  * @type:       the type of the struct this is embedded in.
362  * @member:     the name of the list_head within the struct.
363  */
364 #define list_entry(ptr, type, member) \
365         container_of(ptr, type, member)
366
367 /**
368  * list_first_entry - get the first element from a list
369  * @ptr:        the list head to take the element from.
370  * @type:       the type of the struct this is embedded in.
371  * @member:     the name of the list_head within the struct.
372  *
373  * Note, that list is expected to be not empty.
374  */
375 #define list_first_entry(ptr, type, member) \
376         list_entry((ptr)->next, type, member)
377
378 /**
379  * list_last_entry - get the last element from a list
380  * @ptr:        the list head to take the element from.
381  * @type:       the type of the struct this is embedded in.
382  * @member:     the name of the list_head within the struct.
383  *
384  * Note, that list is expected to be not empty.
385  */
386 #define list_last_entry(ptr, type, member) \
387         list_entry((ptr)->prev, type, member)
388
389 /**
390  * list_first_entry_or_null - get the first element from a list
391  * @ptr:        the list head to take the element from.
392  * @type:       the type of the struct this is embedded in.
393  * @member:     the name of the list_head within the struct.
394  *
395  * Note that if the list is empty, it returns NULL.
396  */
397 #define list_first_entry_or_null(ptr, type, member) ({ \
398         struct list_head *head__ = (ptr); \
399         struct list_head *pos__ = READ_ONCE(head__->next); \
400         pos__ != head__ ? list_entry(pos__, type, member) : NULL; \
401 })
402
403 /**
404  * list_next_entry - get the next element in list
405  * @pos:        the type * to cursor
406  * @member:     the name of the list_head within the struct.
407  */
408 #define list_next_entry(pos, member) \
409         list_entry((pos)->member.next, typeof(*(pos)), member)
410
411 /**
412  * list_prev_entry - get the prev element in list
413  * @pos:        the type * to cursor
414  * @member:     the name of the list_head within the struct.
415  */
416 #define list_prev_entry(pos, member) \
417         list_entry((pos)->member.prev, typeof(*(pos)), member)
418
419 /**
420  * list_for_each        -       iterate over a list
421  * @pos:        the &struct list_head to use as a loop cursor.
422  * @head:       the head for your list.
423  */
424 #define list_for_each(pos, head) \
425         for (pos = (head)->next; pos != (head); pos = pos->next)
426
427 /**
428  * list_for_each_prev   -       iterate over a list backwards
429  * @pos:        the &struct list_head to use as a loop cursor.
430  * @head:       the head for your list.
431  */
432 #define list_for_each_prev(pos, head) \
433         for (pos = (head)->prev; pos != (head); pos = pos->prev)
434
435 /**
436  * list_for_each_safe - iterate over a list safe against removal of list entry
437  * @pos:        the &struct list_head to use as a loop cursor.
438  * @n:          another &struct list_head to use as temporary storage
439  * @head:       the head for your list.
440  */
441 #define list_for_each_safe(pos, n, head) \
442         for (pos = (head)->next, n = pos->next; pos != (head); \
443                 pos = n, n = pos->next)
444
445 /**
446  * list_for_each_prev_safe - iterate over a list backwards safe against removal of list entry
447  * @pos:        the &struct list_head to use as a loop cursor.
448  * @n:          another &struct list_head to use as temporary storage
449  * @head:       the head for your list.
450  */
451 #define list_for_each_prev_safe(pos, n, head) \
452         for (pos = (head)->prev, n = pos->prev; \
453              pos != (head); \
454              pos = n, n = pos->prev)
455
456 /**
457  * list_for_each_entry  -       iterate over list of given type
458  * @pos:        the type * to use as a loop cursor.
459  * @head:       the head for your list.
460  * @member:     the name of the list_head within the struct.
461  */
462 #define list_for_each_entry(pos, head, member)                          \
463         for (pos = list_first_entry(head, typeof(*pos), member);        \
464              &pos->member != (head);                                    \
465              pos = list_next_entry(pos, member))
466
467 /**
468  * list_for_each_entry_reverse - iterate backwards over list of given type.
469  * @pos:        the type * to use as a loop cursor.
470  * @head:       the head for your list.
471  * @member:     the name of the list_head within the struct.
472  */
473 #define list_for_each_entry_reverse(pos, head, member)                  \
474         for (pos = list_last_entry(head, typeof(*pos), member);         \
475              &pos->member != (head);                                    \
476              pos = list_prev_entry(pos, member))
477
478 /**
479  * list_prepare_entry - prepare a pos entry for use in list_for_each_entry_continue()
480  * @pos:        the type * to use as a start point
481  * @head:       the head of the list
482  * @member:     the name of the list_head within the struct.
483  *
484  * Prepares a pos entry for use as a start point in list_for_each_entry_continue().
485  */
486 #define list_prepare_entry(pos, head, member) \
487         ((pos) ? : list_entry(head, typeof(*pos), member))
488
489 /**
490  * list_for_each_entry_continue - continue iteration over list of given type
491  * @pos:        the type * to use as a loop cursor.
492  * @head:       the head for your list.
493  * @member:     the name of the list_head within the struct.
494  *
495  * Continue to iterate over list of given type, continuing after
496  * the current position.
497  */
498 #define list_for_each_entry_continue(pos, head, member)                 \
499         for (pos = list_next_entry(pos, member);                        \
500              &pos->member != (head);                                    \
501              pos = list_next_entry(pos, member))
502
503 /**
504  * list_for_each_entry_continue_reverse - iterate backwards from the given point
505  * @pos:        the type * to use as a loop cursor.
506  * @head:       the head for your list.
507  * @member:     the name of the list_head within the struct.
508  *
509  * Start to iterate over list of given type backwards, continuing after
510  * the current position.
511  */
512 #define list_for_each_entry_continue_reverse(pos, head, member)         \
513         for (pos = list_prev_entry(pos, member);                        \
514              &pos->member != (head);                                    \
515              pos = list_prev_entry(pos, member))
516
517 /**
518  * list_for_each_entry_from - iterate over list of given type from the current point
519  * @pos:        the type * to use as a loop cursor.
520  * @head:       the head for your list.
521  * @member:     the name of the list_head within the struct.
522  *
523  * Iterate over list of given type, continuing from current position.
524  */
525 #define list_for_each_entry_from(pos, head, member)                     \
526         for (; &pos->member != (head);                                  \
527              pos = list_next_entry(pos, member))
528
529 /**
530  * list_for_each_entry_from_reverse - iterate backwards over list of given type
531  *                                    from the current point
532  * @pos:        the type * to use as a loop cursor.
533  * @head:       the head for your list.
534  * @member:     the name of the list_head within the struct.
535  *
536  * Iterate backwards over list of given type, continuing from current position.
537  */
538 #define list_for_each_entry_from_reverse(pos, head, member)             \
539         for (; &pos->member != (head);                                  \
540              pos = list_prev_entry(pos, member))
541
542 /**
543  * list_for_each_entry_safe - iterate over list of given type safe against removal of list entry
544  * @pos:        the type * to use as a loop cursor.
545  * @n:          another type * to use as temporary storage
546  * @head:       the head for your list.
547  * @member:     the name of the list_head within the struct.
548  */
549 #define list_for_each_entry_safe(pos, n, head, member)                  \
550         for (pos = list_first_entry(head, typeof(*pos), member),        \
551                 n = list_next_entry(pos, member);                       \
552              &pos->member != (head);                                    \
553              pos = n, n = list_next_entry(n, member))
554
555 /**
556  * list_for_each_entry_safe_continue - continue list iteration safe against removal
557  * @pos:        the type * to use as a loop cursor.
558  * @n:          another type * to use as temporary storage
559  * @head:       the head for your list.
560  * @member:     the name of the list_head within the struct.
561  *
562  * Iterate over list of given type, continuing after current point,
563  * safe against removal of list entry.
564  */
565 #define list_for_each_entry_safe_continue(pos, n, head, member)                 \
566         for (pos = list_next_entry(pos, member),                                \
567                 n = list_next_entry(pos, member);                               \
568              &pos->member != (head);                                            \
569              pos = n, n = list_next_entry(n, member))
570
571 /**
572  * list_for_each_entry_safe_from - iterate over list from current point safe against removal
573  * @pos:        the type * to use as a loop cursor.
574  * @n:          another type * to use as temporary storage
575  * @head:       the head for your list.
576  * @member:     the name of the list_head within the struct.
577  *
578  * Iterate over list of given type from current point, safe against
579  * removal of list entry.
580  */
581 #define list_for_each_entry_safe_from(pos, n, head, member)                     \
582         for (n = list_next_entry(pos, member);                                  \
583              &pos->member != (head);                                            \
584              pos = n, n = list_next_entry(n, member))
585
586 /**
587  * list_for_each_entry_safe_reverse - iterate backwards over list safe against removal
588  * @pos:        the type * to use as a loop cursor.
589  * @n:          another type * to use as temporary storage
590  * @head:       the head for your list.
591  * @member:     the name of the list_head within the struct.
592  *
593  * Iterate backwards over list of given type, safe against removal
594  * of list entry.
595  */
596 #define list_for_each_entry_safe_reverse(pos, n, head, member)          \
597         for (pos = list_last_entry(head, typeof(*pos), member),         \
598                 n = list_prev_entry(pos, member);                       \
599              &pos->member != (head);                                    \
600              pos = n, n = list_prev_entry(n, member))
601
602 /**
603  * list_safe_reset_next - reset a stale list_for_each_entry_safe loop
604  * @pos:        the loop cursor used in the list_for_each_entry_safe loop
605  * @n:          temporary storage used in list_for_each_entry_safe
606  * @member:     the name of the list_head within the struct.
607  *
608  * list_safe_reset_next is not safe to use in general if the list may be
609  * modified concurrently (eg. the lock is dropped in the loop body). An
610  * exception to this is if the cursor element (pos) is pinned in the list,
611  * and list_safe_reset_next is called after re-taking the lock and before
612  * completing the current iteration of the loop body.
613  */
614 #define list_safe_reset_next(pos, n, member)                            \
615         n = list_next_entry(pos, member)
616
617 /*
618  * Double linked lists with a single pointer list head.
619  * Mostly useful for hash tables where the two pointer list head is
620  * too wasteful.
621  * You lose the ability to access the tail in O(1).
622  */
623
624 #define HLIST_HEAD_INIT { .first = NULL }
625 #define HLIST_HEAD(name) struct hlist_head name = {  .first = NULL }
626 #define INIT_HLIST_HEAD(ptr) ((ptr)->first = NULL)
627 static inline void INIT_HLIST_NODE(struct hlist_node *h)
628 {
629         h->next = NULL;
630         h->pprev = NULL;
631 }
632
633 static inline int hlist_unhashed(const struct hlist_node *h)
634 {
635         return !h->pprev;
636 }
637
638 static inline int hlist_empty(const struct hlist_head *h)
639 {
640         return !READ_ONCE(h->first);
641 }
642
643 static inline void __hlist_del(struct hlist_node *n)
644 {
645         struct hlist_node *next = n->next;
646         struct hlist_node **pprev = n->pprev;
647
648         WRITE_ONCE(*pprev, next);
649         if (next)
650                 next->pprev = pprev;
651 }
652
653 static inline void hlist_del(struct hlist_node *n)
654 {
655         __hlist_del(n);
656         n->next = LIST_POISON1;
657         n->pprev = LIST_POISON2;
658 }
659
660 static inline void hlist_del_init(struct hlist_node *n)
661 {
662         if (!hlist_unhashed(n)) {
663                 __hlist_del(n);
664                 INIT_HLIST_NODE(n);
665         }
666 }
667
668 static inline void hlist_add_head(struct hlist_node *n, struct hlist_head *h)
669 {
670         struct hlist_node *first = h->first;
671         n->next = first;
672         if (first)
673                 first->pprev = &n->next;
674         WRITE_ONCE(h->first, n);
675         n->pprev = &h->first;
676 }
677
678 /* next must be != NULL */
679 static inline void hlist_add_before(struct hlist_node *n,
680                                         struct hlist_node *next)
681 {
682         n->pprev = next->pprev;
683         n->next = next;
684         next->pprev = &n->next;
685         WRITE_ONCE(*(n->pprev), n);
686 }
687
688 static inline void hlist_add_behind(struct hlist_node *n,
689                                     struct hlist_node *prev)
690 {
691         n->next = prev->next;
692         WRITE_ONCE(prev->next, n);
693         n->pprev = &prev->next;
694
695         if (n->next)
696                 n->next->pprev  = &n->next;
697 }
698
699 /* after that we'll appear to be on some hlist and hlist_del will work */
700 static inline void hlist_add_fake(struct hlist_node *n)
701 {
702         n->pprev = &n->next;
703 }
704
705 static inline bool hlist_fake(struct hlist_node *h)
706 {
707         return h->pprev == &h->next;
708 }
709
710 /*
711  * Check whether the node is the only node of the head without
712  * accessing head:
713  */
714 static inline bool
715 hlist_is_singular_node(struct hlist_node *n, struct hlist_head *h)
716 {
717         return !n->next && n->pprev == &h->first;
718 }
719
720 /*
721  * Move a list from one list head to another. Fixup the pprev
722  * reference of the first entry if it exists.
723  */
724 static inline void hlist_move_list(struct hlist_head *old,
725                                    struct hlist_head *new)
726 {
727         new->first = old->first;
728         if (new->first)
729                 new->first->pprev = &new->first;
730         old->first = NULL;
731 }
732
733 #define hlist_entry(ptr, type, member) container_of(ptr,type,member)
734
735 #define hlist_for_each(pos, head) \
736         for (pos = (head)->first; pos ; pos = pos->next)
737
738 #define hlist_for_each_safe(pos, n, head) \
739         for (pos = (head)->first; pos && ({ n = pos->next; 1; }); \
740              pos = n)
741
742 #define hlist_entry_safe(ptr, type, member) \
743         ({ typeof(ptr) ____ptr = (ptr); \
744            ____ptr ? hlist_entry(____ptr, type, member) : NULL; \
745         })
746
747 /**
748  * hlist_for_each_entry - iterate over list of given type
749  * @pos:        the type * to use as a loop cursor.
750  * @head:       the head for your list.
751  * @member:     the name of the hlist_node within the struct.
752  */
753 #define hlist_for_each_entry(pos, head, member)                         \
754         for (pos = hlist_entry_safe((head)->first, typeof(*(pos)), member);\
755              pos;                                                       \
756              pos = hlist_entry_safe((pos)->member.next, typeof(*(pos)), member))
757
758 /**
759  * hlist_for_each_entry_continue - iterate over a hlist continuing after current point
760  * @pos:        the type * to use as a loop cursor.
761  * @member:     the name of the hlist_node within the struct.
762  */
763 #define hlist_for_each_entry_continue(pos, member)                      \
764         for (pos = hlist_entry_safe((pos)->member.next, typeof(*(pos)), member);\
765              pos;                                                       \
766              pos = hlist_entry_safe((pos)->member.next, typeof(*(pos)), member))
767
768 /**
769  * hlist_for_each_entry_from - iterate over a hlist continuing from current point
770  * @pos:        the type * to use as a loop cursor.
771  * @member:     the name of the hlist_node within the struct.
772  */
773 #define hlist_for_each_entry_from(pos, member)                          \
774         for (; pos;                                                     \
775              pos = hlist_entry_safe((pos)->member.next, typeof(*(pos)), member))
776
777 /**
778  * hlist_for_each_entry_safe - iterate over list of given type safe against removal of list entry
779  * @pos:        the type * to use as a loop cursor.
780  * @n:          another &struct hlist_node to use as temporary storage
781  * @head:       the head for your list.
782  * @member:     the name of the hlist_node within the struct.
783  */
784 #define hlist_for_each_entry_safe(pos, n, head, member)                 \
785         for (pos = hlist_entry_safe((head)->first, typeof(*pos), member);\
786              pos && ({ n = pos->member.next; 1; });                     \
787              pos = hlist_entry_safe(n, typeof(*pos), member))
788
789 #endif