util/list: Add list splicing functions
authorJason Ekstrand <jason.ekstrand@intel.com>
Thu, 30 Jul 2015 18:28:22 +0000 (11:28 -0700)
committerJason Ekstrand <jason.ekstrand@intel.com>
Thu, 30 Jul 2015 18:28:22 +0000 (11:28 -0700)
This adds functions for splicing one list into another.  These have
more-or-less the same API as the kernel list splicing functions.

src/util/list.h

index b98ce59ff77d6c6344f6147fe13214b022c7a863..d4b485174fc7391fc2dde6a127e7d224dc02d75f 100644 (file)
@@ -108,6 +108,28 @@ static inline unsigned list_length(struct list_head *list)
    return length;
 }
 
+static inline void list_splice(struct list_head *src, struct list_head *dst)
+{
+   if (list_empty(src))
+      return;
+
+   src->next->prev = dst;
+   src->prev->next = dst->next;
+   dst->next->prev = src->prev;
+   dst->next = src->next;
+}
+
+static inline void list_splicetail(struct list_head *src, struct list_head *dst)
+{
+   if (list_empty(src))
+      return;
+
+   src->prev->next = dst;
+   src->next->prev = dst->prev;
+   dst->prev->next = src->next;
+   dst->prev = src->prev;
+}
+
 static inline void list_validate(struct list_head *list)
 {
    struct list_head *node;