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)