projects
/
urcu.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix: i386 compat code duplicated mutex instances
[urcu.git]
/
urcu-call-rcu.h
diff --git
a/urcu-call-rcu.h
b/urcu-call-rcu.h
index f965911ebfc8b61e08e1af2b63b6c109c9e26a8b..e71c69cbe62cc6328a7924f02f85bca3e9f758b3 100644
(file)
--- a/
urcu-call-rcu.h
+++ b/
urcu-call-rcu.h
@@
-44,8
+44,12
@@
struct call_rcu_data;
/* Flag values. */
/* Flag values. */
-#define URCU_CALL_RCU_RT 0x1
-#define URCU_CALL_RCU_RUNNING 0x2
+#define URCU_CALL_RCU_RT (1U << 0)
+#define URCU_CALL_RCU_RUNNING (1U << 1)
+#define URCU_CALL_RCU_STOP (1U << 2)
+#define URCU_CALL_RCU_STOPPED (1U << 3)
+#define URCU_CALL_RCU_PAUSE (1U << 4)
+#define URCU_CALL_RCU_PAUSED (1U << 5)
/*
* The rcu_head data structure is placed in the structure to be freed
/*
* The rcu_head data structure is placed in the structure to be freed
@@
-59,18
+63,34
@@
struct rcu_head {
/*
* Exported functions
/*
* Exported functions
+ *
+ * Important: see rcu-api.txt in userspace-rcu documentation for
+ * call_rcu family of functions usage detail, including the surrounding
+ * RCU usage required when using these primitives.
*/
*/
-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);
-int set_cpu_call_rcu_data(int cpu, struct call_rcu_data *crdp);
+
+void call_rcu(struct rcu_head *head,
+ void (*func)(struct rcu_head *head));
+
+struct call_rcu_data *create_call_rcu_data(unsigned long flags,
+ int cpu_affinity);
+void call_rcu_data_free(struct call_rcu_data *crdp);
+
struct call_rcu_data *get_default_call_rcu_data(void);
struct call_rcu_data *get_default_call_rcu_data(void);
-struct call_rcu_data *get_c
all_rcu_data(void
);
+struct call_rcu_data *get_c
pu_call_rcu_data(int cpu
);
struct call_rcu_data *get_thread_call_rcu_data(void);
struct call_rcu_data *get_thread_call_rcu_data(void);
+struct call_rcu_data *get_call_rcu_data(void);
+pthread_t get_call_rcu_thread(struct call_rcu_data *crdp);
+
void set_thread_call_rcu_data(struct call_rcu_data *crdp);
void set_thread_call_rcu_data(struct call_rcu_data *crdp);
+int set_cpu_call_rcu_data(int cpu, struct call_rcu_data *crdp);
+
int create_all_cpu_call_rcu_data(unsigned long flags);
int create_all_cpu_call_rcu_data(unsigned long flags);
-void call_rcu(struct rcu_head *head,
- void (*func)(struct rcu_head *head));
+void free_all_cpu_call_rcu_data(void);
+
+void call_rcu_before_fork(void);
+void call_rcu_after_fork_parent(void);
+void call_rcu_after_fork_child(void);
#ifdef __cplusplus
}
#ifdef __cplusplus
}
This page took
0.024496 seconds
and
4
git commands to generate.