|
Subject: [PATCH] add an RCU version of list splicing Newsgroups: gmane.linux.kernel.openipmi, gmane.linux.kernel Date: 2007-01-03 15:27:38 GMT (2 years, 26 weeks, 16 hours and 12 minutes ago) This patch is in support of the IPMI driver. I have tested this with the IPMI driver changes coming in the next patch. Add a list_splice_init_rcu() function to splice an RCU-protected list into another list. This takes the sync function as an argument, so one would do something like: INIT_LIST_HEAD(&list); list_splice_init_rcu(&source, &dest, synchronize_rcu); The idea being to keep the RCU API proliferation down to a dull roar. Signed-off-by: Paul E. McKenney <paulmck <at> linux.vnet.ibm.com> Signed-off-by: Corey Minyard <minyard <at> acm.org> --- list.h | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) Index: linux-2.6.19/include/linux/list.h =================================================================== --- linux-2.6.19.orig/include/linux/list.h 2006-11-29 15:57:37.000000000 -0600 +++ linux-2.6.19/include/linux/list.h 2006-12-30 12:47:07.000000000 -0600 @@ -360,6 +360,63 @@ } /** + * list_splice_init_rcu - splice an RCU-protected list into an existing list. + * @list: the RCU-protected list to splice + * @head: the place in the list to splice the first list into + * @sync: function to sync: synchronize_rcu(), synchronize_sched(), ... + * + * @head can be RCU-read traversed concurrently with this function. + * + * Note that this function blocks. + * + * Important note: the caller must take whatever action is necessary to + * prevent any other updates to @head. In principle, it is possible + * to modify the list as soon as sync() begins execution. + * If this sort of thing becomes necessary, an alternative version + * based on call_rcu() could be created. But only if - |
|
|