19 #ifndef _COBALT_KERNEL_LIST_H
20 #define _COBALT_KERNEL_LIST_H
22 #include <linux/list.h>
24 #define __list_add_pri(__new, __head, __member_pri, __member_next, __relop) \
26 typeof(*__new) *__pos; \
27 if (list_empty(__head)) \
28 list_add(&(__new)->__member_next, __head); \
30 list_for_each_entry_reverse(__pos, __head, __member_next) { \
31 if ((__new)->__member_pri __relop __pos->__member_pri) \
34 list_add(&(__new)->__member_next, &__pos->__member_next); \
38 #define list_add_priff(__new, __head, __member_pri, __member_next) \
39 __list_add_pri(__new, __head, __member_pri, __member_next, <=)
41 #define list_add_prilf(__new, __head, __member_pri, __member_next) \
42 __list_add_pri(__new, __head, __member_pri, __member_next, <)
44 #define list_get_entry(__head, __type, __member) \
47 __item = list_first_entry(__head, __type, __member); \
48 list_del(&__item->__member); \
52 #define list_get_entry_init(__head, __type, __member) \
55 __item = list_first_entry(__head, __type, __member); \
56 list_del_init(&__item->__member); \
60 #ifndef list_next_entry
61 #define list_next_entry(__item, __member) \
62 list_entry((__item)->__member.next, typeof(*(__item)), __member)