diff options
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 | */ |