X-Git-Url: http://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=urcu-call-rcu.h;h=e76a844018f2e24a129ab1e3db957ec90f6cdf40;hp=f965911ebfc8b61e08e1af2b63b6c109c9e26a8b;hb=e0ab43eb922df8fee5f28416d41fa3b2ca4a7a43;hpb=3c24913f970c2dc1dab0a00e3ee9683250667f82 diff --git a/urcu-call-rcu.h b/urcu-call-rcu.h index f965911..e76a844 100644 --- a/urcu-call-rcu.h +++ b/urcu-call-rcu.h @@ -46,6 +46,8 @@ struct call_rcu_data; #define URCU_CALL_RCU_RT 0x1 #define URCU_CALL_RCU_RUNNING 0x2 +#define URCU_CALL_RCU_STOP 0x4 +#define URCU_CALL_RCU_STOPPED 0x8 /* * The rcu_head data structure is placed in the structure to be freed @@ -62,7 +64,8 @@ struct rcu_head { */ struct call_rcu_data *get_cpu_call_rcu_data(int cpu); pthread_t get_call_rcu_thread(struct call_rcu_data *crdp); -struct call_rcu_data *create_call_rcu_data(unsigned long flags); +struct call_rcu_data *create_call_rcu_data(unsigned long flags, + int cpu_affinity); int set_cpu_call_rcu_data(int cpu, struct call_rcu_data *crdp); struct call_rcu_data *get_default_call_rcu_data(void); struct call_rcu_data *get_call_rcu_data(void); @@ -71,6 +74,9 @@ void set_thread_call_rcu_data(struct call_rcu_data *crdp); int create_all_cpu_call_rcu_data(unsigned long flags); void call_rcu(struct rcu_head *head, void (*func)(struct rcu_head *head)); +void call_rcu_data_free(struct call_rcu_data *crdp); +void free_all_cpu_call_rcu_data(void); +void call_rcu_after_fork_child(void); #ifdef __cplusplus }