diff options
author | Frederic Weisbecker <fweisbec@gmail.com> | 2008-11-23 18:43:39 +0100 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-11-23 22:34:02 +0100 |
commit | 65afa5e603d507014580ead016ec887b49e1afa6 (patch) | |
tree | 0ee309e4193e90587b2febda09143891e0591cdc /kernel/exit.c | |
parent | eae849ca034c7f1015f0a6f17421ebc737f0a069 (diff) | |
download | kernel-crypto-65afa5e603d507014580ead016ec887b49e1afa6.tar.gz kernel-crypto-65afa5e603d507014580ead016ec887b49e1afa6.tar.xz kernel-crypto-65afa5e603d507014580ead016ec887b49e1afa6.zip |
tracing/function-return-tracer: free the return stack on free_task()
Impact: avoid losing some traces when a task is freed
do_exit() is not the last function called when a task finishes.
There are still some functions which are to be called such as
ree_task(). So we delay the freeing of the return stack to the
last moment.
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/exit.c')
-rw-r--r-- | kernel/exit.c | 2 |
1 files changed, 0 insertions, 2 deletions
diff --git a/kernel/exit.c b/kernel/exit.c index ef04d03b328..e5ae36ebe8a 100644 --- a/kernel/exit.c +++ b/kernel/exit.c @@ -47,7 +47,6 @@ #include <linux/task_io_accounting_ops.h> #include <linux/tracehook.h> #include <trace/sched.h> -#include <linux/ftrace.h> #include <asm/uaccess.h> #include <asm/unistd.h> @@ -1128,7 +1127,6 @@ NORET_TYPE void do_exit(long code) preempt_disable(); /* causes final put_task_struct in finish_task_switch(). */ tsk->state = TASK_DEAD; - ftrace_retfunc_exit_task(tsk); schedule(); BUG(); /* Avoid "noreturn function does return". */ |