rculist.h: Add list_tail_rcu()
authorMadhuparna Bhowmik <madhuparnabhowmik04@gmail.com>
Mon, 9 Dec 2019 07:50:43 +0000 (13:20 +0530)
committerPaul E. McKenney <paulmck@kernel.org>
Fri, 10 Jan 2020 22:00:58 +0000 (14:00 -0800)
This patch adds the macro list_tail_rcu() and documents it.

Signed-off-by: Madhuparna Bhowmik <madhuparnabhowmik04@gmail.com>
[ paulmck: Reword a bit. ]
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
include/linux/rculist.h

index 4b7ae1b..9f313e4 100644 (file)
@@ -40,6 +40,16 @@ static inline void INIT_LIST_HEAD_RCU(struct list_head *list)
  */
 #define list_next_rcu(list)    (*((struct list_head __rcu **)(&(list)->next)))
 
+/**
+ * list_tail_rcu - returns the prev pointer of the head of the list
+ * @head: the head of the list
+ *
+ * Note: This should only be used with the list header, and even then
+ * only if list_del() and similar primitives are not also used on the
+ * list header.
+ */
+#define list_tail_rcu(head)    (*((struct list_head __rcu **)(&(head)->prev)))
+
 /*
  * Check during list traversal that we are within an RCU reader
  */