X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=kernel%2Frcupdate.c;h=d92a76a881aa47a9aa059c3221910834f6c50cf8;hb=104cbd55377029e70fc2cee01089e84b9c36e5dc;hp=ad63af8b25218f562729d868293285ce3433cff8;hpb=9649745c8670eacc671e9cff72c5c1e346e13036;p=deliverable%2Flinux.git diff --git a/kernel/rcupdate.c b/kernel/rcupdate.c index ad63af8b2521..d92a76a881aa 100644 --- a/kernel/rcupdate.c +++ b/kernel/rcupdate.c @@ -77,8 +77,15 @@ void wakeme_after_rcu(struct rcu_head *head) * sections are delimited by rcu_read_lock() and rcu_read_unlock(), * and may be nested. */ -void synchronize_rcu(void); /* Makes kernel-doc tools happy */ -synchronize_rcu_xxx(synchronize_rcu, call_rcu) +void synchronize_rcu(void) +{ + struct rcu_synchronize rcu; + init_completion(&rcu.completion); + /* Will wake me after RCU finished. */ + call_rcu(&rcu.head, wakeme_after_rcu); + /* Wait for it. */ + wait_for_completion(&rcu.completion); +} EXPORT_SYMBOL_GPL(synchronize_rcu); static void rcu_barrier_callback(struct rcu_head *notused)