diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2010-10-14 10:54:51 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-10-18 13:58:52 -0400 |
commit | e7d0bc047548d76feee6b23f7d3d9da927189a50 (patch) | |
tree | be1cd1fc48f6458a2efa4d0bfac53808938208dc /kernel/perf_event.c | |
parent | 74c3337c2fc6389d3a57a622a936036b6db6b2e8 (diff) |
perf: Fix task refcount bugs
Currently it looks like find_lively_task_by_vpid() takes a task ref
and relies on find_get_context() to drop it.
The problem is that perf_event_create_kernel_counter() shouldn't be
dropping task refs.
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Frederic Weisbecker <fweisbec@gmail.com>
Acked-by: Matt Helsley <matthltc@us.ibm.com>
LKML-Reference: <20101014203625.278436085@chello.nl>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/perf_event.c')
-rw-r--r-- | kernel/perf_event.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/kernel/perf_event.c b/kernel/perf_event.c index 346dc0e35a0a..f928878a1c17 100644 --- a/kernel/perf_event.c +++ b/kernel/perf_event.c | |||
@@ -2190,11 +2190,9 @@ retry: | |||
2190 | } | 2190 | } |
2191 | } | 2191 | } |
2192 | 2192 | ||
2193 | put_task_struct(task); | ||
2194 | return ctx; | 2193 | return ctx; |
2195 | 2194 | ||
2196 | errout: | 2195 | errout: |
2197 | put_task_struct(task); | ||
2198 | return ERR_PTR(err); | 2196 | return ERR_PTR(err); |
2199 | } | 2197 | } |
2200 | 2198 | ||
@@ -5602,7 +5600,7 @@ SYSCALL_DEFINE5(perf_event_open, | |||
5602 | ctx = find_get_context(pmu, task, cpu); | 5600 | ctx = find_get_context(pmu, task, cpu); |
5603 | if (IS_ERR(ctx)) { | 5601 | if (IS_ERR(ctx)) { |
5604 | err = PTR_ERR(ctx); | 5602 | err = PTR_ERR(ctx); |
5605 | goto err_group_fd; | 5603 | goto err_task; |
5606 | } | 5604 | } |
5607 | 5605 | ||
5608 | /* | 5606 | /* |
@@ -5698,6 +5696,9 @@ SYSCALL_DEFINE5(perf_event_open, | |||
5698 | 5696 | ||
5699 | err_context: | 5697 | err_context: |
5700 | put_ctx(ctx); | 5698 | put_ctx(ctx); |
5699 | err_task: | ||
5700 | if (task) | ||
5701 | put_task_struct(task); | ||
5701 | err_group_fd: | 5702 | err_group_fd: |
5702 | fput_light(group_file, fput_needed); | 5703 | fput_light(group_file, fput_needed); |
5703 | free_event(event); | 5704 | free_event(event); |