X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=lib%2Flist%2Flist.h;h=53080a034a16bf34dc9042d085f81016f6823864;hp=f78411ea18f7679e058dfaa1f4f6ebb987cc582c;hb=04075cdef04e50b80651a27c5a1573eff0658cc4;hpb=9057583b8b37d07eb9af2fd48674f1732fecda17 diff --git a/lib/list/list.h b/lib/list/list.h index f78411e..53080a0 100644 --- a/lib/list/list.h +++ b/lib/list/list.h @@ -30,17 +30,22 @@ struct list { &pos->member != &(list)->head; \ pos = list_entry(pos->member.next, typeof(*pos), member)) -#define list_for_each_entry_safe(list, pos, n, member) \ - for (pos = list_entry((list)->head.next, typeof(*pos), member), \ - n = list_entry(pos->member.next, typeof(*pos), member); \ - &pos->member != &(list)->head; \ - pos = n, n = list_entry(n->member.next, typeof(*n), member)) - +#define list_for_each_entry_continue(_list, _pos, _member) \ + for (; &_pos->_member != &(_list)->head; \ + _pos = list_entry(_pos->_member.next, typeof(*_pos), _member)) void list_init(struct list *list); - -void list_add(struct list *list, struct list_item *item); - +void list_insert_before(struct list_item *next, struct list_item *item); +void list_insert_after(struct list_item *prev, struct list_item *item); void list_remove(struct list_item *item); +static inline void list_add(struct list *list, struct list_item *item) +{ + list_insert_after(&list->head, item); +} +static inline void list_add_tail(struct list *list, struct list_item *item) +{ + list_insert_before(&list->head, item); +} + #endif /* _LIST_H */