diff options
author | Wu Zhangjin <wuzhangjin@gmail.com> | 2009-11-20 07:34:35 -0500 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2009-12-16 20:57:25 -0500 |
commit | e17ff5fec65a0213416efbe7ceae5f2f9887dda2 (patch) | |
tree | 9f315fcacb075e4e1828fd9e0bd2133e11ec47b2 /arch/mips/kernel/ftrace.c | |
parent | 29c5d3462f7c8f17bb9e0a29f0a299036468074d (diff) |
MIPS: Tracing: Add dynamic function graph tracer for MIPS
This patch make function graph tracer work with dynamic function tracer.
To share the source code of dynamic function tracer(MCOUNT_SAVE_REGS),
and avoid restoring the whole saved registers, we need to restore the ra
register from the stack.
(NOTE: This not work with 32bit! need to ensure why!)
Signed-off-by: Wu Zhangjin <wuzhangjin@gmail.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Nicholas Mc Guire <der.herr@hofr.at>
Cc: zhangfx@lemote.com
Cc: Wu Zhangjin <wuzhangjin@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: linux-kernel@vger.kernel.org
Cc: linux-mips@linux-mips.org
Patchwork: http://patchwork.linux-mips.org/patch/678/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips/kernel/ftrace.c')
-rw-r--r-- | arch/mips/kernel/ftrace.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/arch/mips/kernel/ftrace.c b/arch/mips/kernel/ftrace.c index 65a3f8a89927..e981a497c98f 100644 --- a/arch/mips/kernel/ftrace.c +++ b/arch/mips/kernel/ftrace.c | |||
@@ -115,6 +115,27 @@ int __init ftrace_dyn_arch_init(void *data) | |||
115 | 115 | ||
116 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 116 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
117 | 117 | ||
118 | #ifdef CONFIG_DYNAMIC_FTRACE | ||
119 | |||
120 | extern void ftrace_graph_call(void); | ||
121 | #define JMP 0x08000000 /* jump to target directly */ | ||
122 | #define CALL_FTRACE_GRAPH_CALLER \ | ||
123 | jump_insn_encode(JMP, (unsigned long)(&ftrace_graph_caller)) | ||
124 | #define FTRACE_GRAPH_CALL_IP ((unsigned long)(&ftrace_graph_call)) | ||
125 | |||
126 | int ftrace_enable_ftrace_graph_caller(void) | ||
127 | { | ||
128 | return ftrace_modify_code(FTRACE_GRAPH_CALL_IP, | ||
129 | CALL_FTRACE_GRAPH_CALLER); | ||
130 | } | ||
131 | |||
132 | int ftrace_disable_ftrace_graph_caller(void) | ||
133 | { | ||
134 | return ftrace_modify_code(FTRACE_GRAPH_CALL_IP, ftrace_nop); | ||
135 | } | ||
136 | |||
137 | #endif /* !CONFIG_DYNAMIC_FTRACE */ | ||
138 | |||
118 | #define S_RA_SP (0xafbf << 16) /* s{d,w} ra, offset(sp) */ | 139 | #define S_RA_SP (0xafbf << 16) /* s{d,w} ra, offset(sp) */ |
119 | #define S_R_SP (0xafb0 << 16) /* s{d,w} R, offset(sp) */ | 140 | #define S_R_SP (0xafb0 << 16) /* s{d,w} R, offset(sp) */ |
120 | #define OFFSET_MASK 0xffff /* stack offset range: 0 ~ PT_SIZE */ | 141 | #define OFFSET_MASK 0xffff /* stack offset range: 0 ~ PT_SIZE */ |