diff options
-rw-r--r-- | include/linux/ftrace.h | 3 | ||||
-rw-r--r-- | kernel/exit.c | 2 | ||||
-rw-r--r-- | kernel/fork.c | 2 | ||||
-rw-r--r-- | kernel/sched.c | 2 |
4 files changed, 3 insertions, 6 deletions
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index 2ba259b2defa..938ca1942641 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h | |||
@@ -335,6 +335,9 @@ extern void unregister_ftrace_return(void); | |||
335 | 335 | ||
336 | extern void ftrace_retfunc_init_task(struct task_struct *t); | 336 | extern void ftrace_retfunc_init_task(struct task_struct *t); |
337 | extern void ftrace_retfunc_exit_task(struct task_struct *t); | 337 | extern void ftrace_retfunc_exit_task(struct task_struct *t); |
338 | #else | ||
339 | static inline void ftrace_retfunc_init_task(struct task_struct *t) { } | ||
340 | static inline void ftrace_retfunc_exit_task(struct task_struct *t) { } | ||
338 | #endif | 341 | #endif |
339 | 342 | ||
340 | #endif /* _LINUX_FTRACE_H */ | 343 | #endif /* _LINUX_FTRACE_H */ |
diff --git a/kernel/exit.c b/kernel/exit.c index b9d446329da1..ef04d03b3286 100644 --- a/kernel/exit.c +++ b/kernel/exit.c | |||
@@ -1128,9 +1128,7 @@ NORET_TYPE void do_exit(long code) | |||
1128 | preempt_disable(); | 1128 | preempt_disable(); |
1129 | /* causes final put_task_struct in finish_task_switch(). */ | 1129 | /* causes final put_task_struct in finish_task_switch(). */ |
1130 | tsk->state = TASK_DEAD; | 1130 | tsk->state = TASK_DEAD; |
1131 | #ifdef CONFIG_FUNCTION_RET_TRACER | ||
1132 | ftrace_retfunc_exit_task(tsk); | 1131 | ftrace_retfunc_exit_task(tsk); |
1133 | #endif | ||
1134 | schedule(); | 1132 | schedule(); |
1135 | BUG(); | 1133 | BUG(); |
1136 | /* Avoid "noreturn function does return". */ | 1134 | /* Avoid "noreturn function does return". */ |
diff --git a/kernel/fork.c b/kernel/fork.c index d1eb30e69ccc..fbf4a4c0a628 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
@@ -1270,9 +1270,7 @@ static struct task_struct *copy_process(unsigned long clone_flags, | |||
1270 | total_forks++; | 1270 | total_forks++; |
1271 | spin_unlock(¤t->sighand->siglock); | 1271 | spin_unlock(¤t->sighand->siglock); |
1272 | write_unlock_irq(&tasklist_lock); | 1272 | write_unlock_irq(&tasklist_lock); |
1273 | #ifdef CONFIG_FUNCTION_RET_TRACER | ||
1274 | ftrace_retfunc_init_task(p); | 1273 | ftrace_retfunc_init_task(p); |
1275 | #endif | ||
1276 | proc_fork_connector(p); | 1274 | proc_fork_connector(p); |
1277 | cgroup_post_fork(p); | 1275 | cgroup_post_fork(p); |
1278 | return p; | 1276 | return p; |
diff --git a/kernel/sched.c b/kernel/sched.c index fb17205950de..388d9db044ab 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -5901,9 +5901,7 @@ void __cpuinit init_idle(struct task_struct *idle, int cpu) | |||
5901 | * The idle tasks have their own, simple scheduling class: | 5901 | * The idle tasks have their own, simple scheduling class: |
5902 | */ | 5902 | */ |
5903 | idle->sched_class = &idle_sched_class; | 5903 | idle->sched_class = &idle_sched_class; |
5904 | #ifdef CONFIG_FUNCTION_RET_TRACER | ||
5905 | ftrace_retfunc_init_task(idle); | 5904 | ftrace_retfunc_init_task(idle); |
5906 | #endif | ||
5907 | } | 5905 | } |
5908 | 5906 | ||
5909 | /* | 5907 | /* |