X-Git-Url: http://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=urcu-defer.h;h=43eca34fe2f0c363d9f58a2380d1203541590450;hp=75b600568bc7a2df852cb246e1a300732c6989b8;hb=7be759d1adf95b168f09e513232ea26de15e1eaf;hpb=ec8e44cf2ba50dcb421af40b67e74650bb5057f6 diff --git a/urcu-defer.h b/urcu-defer.h index 75b6005..43eca34 100644 --- a/urcu-defer.h +++ b/urcu-defer.h @@ -6,7 +6,7 @@ * * Userspace RCU header - deferred execution * - * Copyright (c) 2009 Mathieu Desnoyers + * Copyright (c) 2009 Mathieu Desnoyers * Copyright (c) 2009 Paul E. McKenney, IBM Corporation. * * LGPL-compatible code should include this header with : @@ -32,7 +32,14 @@ #include #include +#ifdef __cplusplus +extern "C" { +#endif + /* + * Note: the defer_rcu() API is currently EXPERIMENTAL. It may change in the + * future. + * * Important ! * * Each thread queuing memory reclamation must be registered with @@ -43,17 +50,18 @@ * primitive need to call synchronize_rcu() if the thread queue is full. */ -#define defer_rcu(fct, p) defer_rcu_ratelimit(fct, p, NULL) - -extern void defer_rcu_ratelimit(void (*fct)(void *p), void *p, - int (*rl)(void *p)); +extern void defer_rcu(void (*fct)(void *p), void *p); /* * Thread registration for reclamation. */ -extern void rcu_defer_register_thread(void); +extern int rcu_defer_register_thread(void); extern void rcu_defer_unregister_thread(void); extern void rcu_defer_barrier(void); extern void rcu_defer_barrier_thread(void); +#ifdef __cplusplus +} +#endif + #endif /* _URCU_BATCH_H */