diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2010-09-09 15:01:59 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-09-09 15:07:09 -0400 |
commit | 4e231c7962ce711c7d8c2a4dc23ecd1e8fc28363 (patch) | |
tree | 05af30e5c2f1084d8e77c89f0e55beaafa2194c0 /kernel | |
parent | 1b9a644fece117cfa5474a2388d6b89d1baf8ddf (diff) |
perf: Fix up delayed_put_task_struct()
I missed a perf_event_ctxp user when converting it to an array. Pull this
last user into perf_event.c as well and fix it up.
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <new-submission>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/exit.c | 4 | ||||
-rw-r--r-- | kernel/perf_event.c | 8 |
2 files changed, 9 insertions, 3 deletions
diff --git a/kernel/exit.c b/kernel/exit.c index 03120229db28..e2bdf37f9fde 100644 --- a/kernel/exit.c +++ b/kernel/exit.c | |||
@@ -149,9 +149,7 @@ static void delayed_put_task_struct(struct rcu_head *rhp) | |||
149 | { | 149 | { |
150 | struct task_struct *tsk = container_of(rhp, struct task_struct, rcu); | 150 | struct task_struct *tsk = container_of(rhp, struct task_struct, rcu); |
151 | 151 | ||
152 | #ifdef CONFIG_PERF_EVENTS | 152 | perf_event_delayed_put(tsk); |
153 | WARN_ON_ONCE(tsk->perf_event_ctxp); | ||
154 | #endif | ||
155 | trace_sched_process_free(tsk); | 153 | trace_sched_process_free(tsk); |
156 | put_task_struct(tsk); | 154 | put_task_struct(tsk); |
157 | } | 155 | } |
diff --git a/kernel/perf_event.c b/kernel/perf_event.c index 9819a69a61a1..eaf1c5de6dcc 100644 --- a/kernel/perf_event.c +++ b/kernel/perf_event.c | |||
@@ -5893,6 +5893,14 @@ again: | |||
5893 | } | 5893 | } |
5894 | } | 5894 | } |
5895 | 5895 | ||
5896 | void perf_event_delayed_put(struct task_struct *task) | ||
5897 | { | ||
5898 | int ctxn; | ||
5899 | |||
5900 | for_each_task_context_nr(ctxn) | ||
5901 | WARN_ON_ONCE(task->perf_event_ctxp[ctxn]); | ||
5902 | } | ||
5903 | |||
5896 | /* | 5904 | /* |
5897 | * inherit a event from parent task to child task: | 5905 | * inherit a event from parent task to child task: |
5898 | */ | 5906 | */ |