diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2009-11-23 05:37:26 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-11-23 05:49:56 -0500 |
commit | 5e942bb33371254a474653123cd9e13a4c89ee44 (patch) | |
tree | 2159878d96ea60de9b530b052390b8ca069f1e98 /kernel | |
parent | 2e2af50b1fab3c40636839a7f439c167ae559533 (diff) |
perf_events: Update the context time on exit
It appeared we did call update_event_times() on exit, but we
failed to update the context time, which renders the former
moot.
Locking is a bit iffy, we call update_event_times under
ctx->mutex instead of ctx->lock - the next patch fixes this.
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
LKML-Reference: <20091123103819.764207355@chello.nl>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/perf_event.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/kernel/perf_event.c b/kernel/perf_event.c index fb851ec34461..8be2574b89b6 100644 --- a/kernel/perf_event.c +++ b/kernel/perf_event.c | |||
@@ -4983,6 +4983,7 @@ void perf_event_exit_task(struct task_struct *child) | |||
4983 | * the events from it. | 4983 | * the events from it. |
4984 | */ | 4984 | */ |
4985 | unclone_ctx(child_ctx); | 4985 | unclone_ctx(child_ctx); |
4986 | update_context_time(child_ctx); | ||
4986 | spin_unlock_irqrestore(&child_ctx->lock, flags); | 4987 | spin_unlock_irqrestore(&child_ctx->lock, flags); |
4987 | 4988 | ||
4988 | /* | 4989 | /* |