X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=flist.h;h=8e1304142cc3d3468b79f75872e534220626ce59;hp=e62f4b295e7f843dd565ec426328fefb7470ff5d;hb=91b7a38dc05dba72f15a2fc27c0ab56170423b1b;hpb=2b52511f3f595e0932e7f9c55bed243e8fe0f4f8 diff --git a/flist.h b/flist.h index e62f4b29..8e130414 100644 --- a/flist.h +++ b/flist.h @@ -1,6 +1,8 @@ #ifndef _LINUX_FLIST_H #define _LINUX_FLIST_H +#include + #undef offsetof #ifdef __compiler_offsetof #define offsetof(TYPE,MEMBER) __compiler_offsetof(TYPE,MEMBER) @@ -117,6 +119,36 @@ static inline int flist_empty(const struct flist_head *head) return head->next == head; } +static inline void __flist_splice(const struct flist_head *list, + struct flist_head *prev, + struct flist_head *next) +{ + struct flist_head *first = list->next; + struct flist_head *last = list->prev; + + first->prev = prev; + prev->next = first; + + last->next = next; + next->prev = last; +} + +static inline void flist_splice(const struct flist_head *list, + struct flist_head *head) +{ + if (!flist_empty(list)) + __flist_splice(list, head, head->next); +} + +static inline void flist_splice_init(struct flist_head *list, + struct flist_head *head) +{ + if (!flist_empty(list)) { + __flist_splice(list, head, head->next); + INIT_FLIST_HEAD(list); + } +} + /** * flist_entry - get the struct for this entry * @ptr: the &struct flist_head pointer. @@ -144,4 +176,7 @@ static inline int flist_empty(const struct flist_head *head) for (pos = (head)->next, n = pos->next; pos != (head); \ pos = n, n = pos->next) +extern void flist_sort(void *priv, struct flist_head *head, + int (*cmp)(void *priv, struct flist_head *a, struct flist_head *b)); + #endif