diff options
-rw-r--r-- | include/linux/ftrace.h | 11 | ||||
-rw-r--r-- | kernel/trace/trace.c | 8 |
2 files changed, 12 insertions, 7 deletions
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index b295d3106bfe..b9b4d0a22d10 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h | |||
@@ -8,6 +8,7 @@ | |||
8 | #include <linux/types.h> | 8 | #include <linux/types.h> |
9 | #include <linux/kallsyms.h> | 9 | #include <linux/kallsyms.h> |
10 | #include <linux/bitops.h> | 10 | #include <linux/bitops.h> |
11 | #include <linux/sched.h> | ||
11 | 12 | ||
12 | #ifdef CONFIG_FUNCTION_TRACER | 13 | #ifdef CONFIG_FUNCTION_TRACER |
13 | 14 | ||
@@ -387,9 +388,19 @@ extern void unregister_ftrace_graph(void); | |||
387 | 388 | ||
388 | extern void ftrace_graph_init_task(struct task_struct *t); | 389 | extern void ftrace_graph_init_task(struct task_struct *t); |
389 | extern void ftrace_graph_exit_task(struct task_struct *t); | 390 | extern void ftrace_graph_exit_task(struct task_struct *t); |
391 | |||
392 | static inline int task_curr_ret_stack(struct task_struct *t) | ||
393 | { | ||
394 | return t->curr_ret_stack; | ||
395 | } | ||
390 | #else | 396 | #else |
391 | static inline void ftrace_graph_init_task(struct task_struct *t) { } | 397 | static inline void ftrace_graph_init_task(struct task_struct *t) { } |
392 | static inline void ftrace_graph_exit_task(struct task_struct *t) { } | 398 | static inline void ftrace_graph_exit_task(struct task_struct *t) { } |
399 | |||
400 | static inline int task_curr_ret_stack(struct task_struct *tsk) | ||
401 | { | ||
402 | return -1; | ||
403 | } | ||
393 | #endif | 404 | #endif |
394 | 405 | ||
395 | #ifdef CONFIG_TRACING | 406 | #ifdef CONFIG_TRACING |
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 5dca6ef1fbeb..7a93c663e52a 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c | |||
@@ -3657,13 +3657,7 @@ int __ftrace_printk(unsigned long ip, const char *fmt, ...) | |||
3657 | return 0; | 3657 | return 0; |
3658 | 3658 | ||
3659 | va_start(ap, fmt); | 3659 | va_start(ap, fmt); |
3660 | 3660 | ret = trace_vprintk(ip, task_curr_ret_stack(current), fmt, ap); | |
3661 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | ||
3662 | ret = trace_vprintk(ip, current->curr_ret_stack, fmt, ap); | ||
3663 | #else | ||
3664 | ret = trace_vprintk(ip, -1, fmt, ap); | ||
3665 | #endif | ||
3666 | |||
3667 | va_end(ap); | 3661 | va_end(ap); |
3668 | return ret; | 3662 | return ret; |
3669 | } | 3663 | } |