aboutsummaryrefslogtreecommitdiff
path: root/src/include/lib/ilist.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/include/lib/ilist.h')
-rw-r--r--src/include/lib/ilist.h19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/include/lib/ilist.h b/src/include/lib/ilist.h
index aa196428ed9..ddbdb207afa 100644
--- a/src/include/lib/ilist.h
+++ b/src/include/lib/ilist.h
@@ -395,6 +395,25 @@ dlist_move_head(dlist_head *head, dlist_node *node)
}
/*
+ * Move element from its current position in the list to the tail position in
+ * the same list.
+ *
+ * Undefined behaviour if 'node' is not already part of the list.
+ */
+static inline void
+dlist_move_tail(dlist_head *head, dlist_node *node)
+{
+ /* fast path if it's already at the tail */
+ if (head->head.prev == node)
+ return;
+
+ dlist_delete(node);
+ dlist_push_tail(head, node);
+
+ dlist_check(head);
+}
+
+/*
* Check whether 'node' has a following node.
* Caution: unreliable if 'node' is not in the list.
*/