From 756dcb51db7d6104fe8099ebcc89186b6418ffef Mon Sep 17 00:00:00 2001 From: Peter Zijlstra Date: Sat, 9 Apr 2011 21:17:41 +0200 Subject: [PATCH] --- yaml --- r: 257016 b: refs/heads/master c: 9137fb28ac74d05eb66d1d8e6778eaa14e6fed43 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/kernel/events/core.c | 10 +++------- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/[refs] b/[refs] index 16df278f4345..938ee2d20fed 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 075e0b00857e166dcc3e39037a1fc5a90acac709 +refs/heads/master: 9137fb28ac74d05eb66d1d8e6778eaa14e6fed43 diff --git a/trunk/kernel/events/core.c b/trunk/kernel/events/core.c index 4d9a1f014286..d665ac4242f2 100644 --- a/trunk/kernel/events/core.c +++ b/trunk/kernel/events/core.c @@ -2835,16 +2835,12 @@ find_get_context(struct pmu *pmu, struct task_struct *task, int cpu) unclone_ctx(ctx); ++ctx->pin_count; raw_spin_unlock_irqrestore(&ctx->lock, flags); - } - - if (!ctx) { + } else { ctx = alloc_perf_context(pmu, task); err = -ENOMEM; if (!ctx) goto errout; - get_ctx(ctx); - err = 0; mutex_lock(&task->perf_event_mutex); /* @@ -2856,14 +2852,14 @@ find_get_context(struct pmu *pmu, struct task_struct *task, int cpu) else if (task->perf_event_ctxp[ctxn]) err = -EAGAIN; else { + get_ctx(ctx); ++ctx->pin_count; rcu_assign_pointer(task->perf_event_ctxp[ctxn], ctx); } mutex_unlock(&task->perf_event_mutex); if (unlikely(err)) { - put_task_struct(task); - kfree(ctx); + put_ctx(ctx); if (err == -EAGAIN) goto retry;