Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 147475
b: refs/heads/master
c: 33b2fb3
h: refs/heads/master
i:
  147473: ac0874b
  147471: 8a61200
v: v3
  • Loading branch information
Ingo Molnar committed May 19, 2009
1 parent 45a9ce0 commit f835224
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 13 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: b68f1d2e7aa21029d73c7d453a8046e95d351740
refs/heads/master: 33b2fb303fe7f6b08bbb32f708e67b96eaa94a7a
19 changes: 7 additions & 12 deletions trunk/kernel/exit.c
Original file line number Diff line number Diff line change
Expand Up @@ -178,12 +178,6 @@ void release_task(struct task_struct * p)

proc_flush_task(p);

/*
* Flush inherited counters to the parent - before the parent
* gets woken up by child-exit notifications.
*/
perf_counter_exit_task(p);

write_lock_irq(&tasklist_lock);
tracehook_finish_release_task(p);
__exit_signal(p);
Expand Down Expand Up @@ -985,6 +979,13 @@ NORET_TYPE void do_exit(long code)
module_put(tsk->binfmt->module);

proc_exit_connector(tsk);

/*
* Flush inherited counters to the parent - before the parent
* gets woken up by child-exit notifications.
*/
perf_counter_exit_task(tsk);

exit_notify(tsk, group_dead);
#ifdef CONFIG_NUMA
mpol_put(tsk->mempolicy);
Expand Down Expand Up @@ -1257,12 +1258,6 @@ static int wait_task_zombie(struct task_struct *p, int options,
*/
read_unlock(&tasklist_lock);

/*
* Flush inherited counters to the parent - before the parent
* gets woken up by child-exit notifications.
*/
perf_counter_exit_task(p);

retval = ru ? getrusage(p, RUSAGE_BOTH, ru) : 0;
status = (p->signal->flags & SIGNAL_GROUP_EXIT)
? p->signal->group_exit_code : p->exit_code;
Expand Down
2 changes: 2 additions & 0 deletions trunk/kernel/perf_counter.c
Original file line number Diff line number Diff line change
Expand Up @@ -3299,6 +3299,8 @@ void perf_counter_exit_task(struct task_struct *child)
struct perf_counter *child_counter, *tmp;
struct perf_counter_context *child_ctx;

WARN_ON_ONCE(child != current);

child_ctx = &child->perf_counter_ctx;

if (likely(!child_ctx->nr_counters))
Expand Down

0 comments on commit f835224

Please sign in to comment.