diff options
author | Paul E. McKenney <paulmck@linux.vnet.ibm.com> | 2014-06-27 16:42:20 -0400 |
---|---|---|
committer | Paul E. McKenney <paulmck@linux.vnet.ibm.com> | 2014-09-07 19:27:19 -0400 |
commit | 8315f42295d2667a7f942f154b73a86fd7cb2227 (patch) | |
tree | 67057935dada3305e0dab95f546359b40cc29b96 /include/linux/init_task.h | |
parent | 11ed7f934cb807f26da09547b5946c2e534d1dac (diff) |
rcu: Add call_rcu_tasks()
This commit adds a new RCU-tasks flavor of RCU, which provides
call_rcu_tasks(). This RCU flavor's quiescent states are voluntary
context switch (not preemption!) and userspace execution (not the idle
loop -- use some sort of schedule_on_each_cpu() if you need to handle the
idle tasks. Note that unlike other RCU flavors, these quiescent states
occur in tasks, not necessarily CPUs. Includes fixes from Steven Rostedt.
This RCU flavor is assumed to have very infrequent latency-tolerant
updaters. This assumption permits significant simplifications, including
a single global callback list protected by a single global lock, along
with a single task-private linked list containing all tasks that have not
yet passed through a quiescent state. If experience shows this assumption
to be incorrect, the required additional complexity will be added.
Suggested-by: Steven Rostedt <rostedt@goodmis.org>
Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Diffstat (limited to 'include/linux/init_task.h')
-rw-r--r-- | include/linux/init_task.h | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/include/linux/init_task.h b/include/linux/init_task.h index 2bb4c4f3531a..dffd9258ee60 100644 --- a/include/linux/init_task.h +++ b/include/linux/init_task.h | |||
@@ -117,6 +117,14 @@ extern struct group_info init_groups; | |||
117 | #else | 117 | #else |
118 | #define INIT_TASK_RCU_PREEMPT(tsk) | 118 | #define INIT_TASK_RCU_PREEMPT(tsk) |
119 | #endif | 119 | #endif |
120 | #ifdef CONFIG_TASKS_RCU | ||
121 | #define INIT_TASK_RCU_TASKS(tsk) \ | ||
122 | .rcu_tasks_holdout = false, \ | ||
123 | .rcu_tasks_holdout_list = \ | ||
124 | LIST_HEAD_INIT(tsk.rcu_tasks_holdout_list), | ||
125 | #else | ||
126 | #define INIT_TASK_RCU_TASKS(tsk) | ||
127 | #endif | ||
120 | 128 | ||
121 | extern struct cred init_cred; | 129 | extern struct cred init_cred; |
122 | 130 | ||
@@ -224,6 +232,7 @@ extern struct task_group root_task_group; | |||
224 | INIT_FTRACE_GRAPH \ | 232 | INIT_FTRACE_GRAPH \ |
225 | INIT_TRACE_RECURSION \ | 233 | INIT_TRACE_RECURSION \ |
226 | INIT_TASK_RCU_PREEMPT(tsk) \ | 234 | INIT_TASK_RCU_PREEMPT(tsk) \ |
235 | INIT_TASK_RCU_TASKS(tsk) \ | ||
227 | INIT_CPUSET_SEQ(tsk) \ | 236 | INIT_CPUSET_SEQ(tsk) \ |
228 | INIT_RT_MUTEXES(tsk) \ | 237 | INIT_RT_MUTEXES(tsk) \ |
229 | INIT_VTIME(tsk) \ | 238 | INIT_VTIME(tsk) \ |