Merge branch 'master' into urcu/rcuja-range
[userspace-rcu.git] / urcu / rcuhlist.h
index 69c4d3184fd50d7f38a730e17447678f5fec3991..b07c66b65ff1ccd33621f08e054594c375127bd7 100644 (file)
@@ -50,6 +50,20 @@ void cds_hlist_del_rcu(struct cds_hlist_node *elem)
        CMM_STORE_SHARED(elem->prev->next, elem->next);
 }
 
+/*
+ * Get first element from a RCU hlist. Assumes the hlist is not empty.
+ * This must be done while rcu_read_lock() is held.
+ */
+#define cds_hlist_first_rcu(ptr, type) \
+       rcu_dereference((ptr)->next)
+
+/*
+ * Get first entry from a RCU hlist. Assumes the hlist is not empty.
+ * This must be done while rcu_read_lock() is held.
+ */
+#define cds_hlist_first_entry_rcu(ptr, type, member) \
+       cds_hlist_entry(rcu_dereference((ptr)->next), type, member)
+
 /*
  * Iterate through elements of the list.
  * This must be done while rcu_read_lock() is held.
This page took 0.022558 seconds and 4 git commands to generate.