X-Git-Url: http://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=urcu-defer.h;h=75b600568bc7a2df852cb246e1a300732c6989b8;hp=e32156c010fdeae325c54b28ee17bb1e72d8d3ec;hb=ec8e44cf2ba50dcb421af40b67e74650bb5057f6;hpb=8a13058c6fb398132fbe05253d1ac55f4cf4cbd1 diff --git a/urcu-defer.h b/urcu-defer.h index e32156c..75b6005 100644 --- a/urcu-defer.h +++ b/urcu-defer.h @@ -39,15 +39,14 @@ * rcu_defer_register_thread(). rcu_defer_unregister_thread() should be * called before the thread exits. * - * *NEVER* use call_rcu()/rcu_defer_queue() within a RCU read-side critical - * section, because this primitive need to call synchronize_rcu() if the thread - * queue is full. + * *NEVER* use defer_rcu() within a RCU read-side critical section, because this + * primitive need to call synchronize_rcu() if the thread queue is full. */ -#define call_rcu rcu_defer_queue -#define rcu_reclaim_queue(p) rcu_defer_queue(free, p) +#define defer_rcu(fct, p) defer_rcu_ratelimit(fct, p, NULL) -extern void rcu_defer_queue(void (*fct)(void *p), void *p); +extern void defer_rcu_ratelimit(void (*fct)(void *p), void *p, + int (*rl)(void *p)); /* * Thread registration for reclamation.