diff options
author | Michal Simek <monstr@monstr.eu> | 2009-11-16 04:32:10 -0500 |
---|---|---|
committer | Michal Simek <monstr@monstr.eu> | 2009-12-14 02:44:53 -0500 |
commit | a0d3e66522e8f6119f002cf31e5d92d7ae73b409 (patch) | |
tree | 717d36ef5a2e103669403011317a88b1af84c9d3 /arch/microblaze/kernel/mcount.S | |
parent | 7d241ff0567b9503d79ee775c40927d09b509f83 (diff) |
microblaze: ftrace: add function graph support
For more information look at Documentation/trace folder.
Signed-off-by: Michal Simek <monstr@monstr.eu>
Diffstat (limited to 'arch/microblaze/kernel/mcount.S')
-rw-r--r-- | arch/microblaze/kernel/mcount.S | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/arch/microblaze/kernel/mcount.S b/arch/microblaze/kernel/mcount.S index 30aaf8fb55b2..84a19458c74d 100644 --- a/arch/microblaze/kernel/mcount.S +++ b/arch/microblaze/kernel/mcount.S | |||
@@ -96,6 +96,27 @@ ENTRY(ftrace_caller) | |||
96 | bneid r5, end; | 96 | bneid r5, end; |
97 | nop; | 97 | nop; |
98 | /* MS: HAVE_FUNCTION_TRACE_MCOUNT_TEST end of checking */ | 98 | /* MS: HAVE_FUNCTION_TRACE_MCOUNT_TEST end of checking */ |
99 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | ||
100 | lwi r5, r0, ftrace_graph_return; | ||
101 | addik r6, r0, ftrace_stub; /* asm implementation */ | ||
102 | cmpu r5, r5, r6; /* ftrace_graph_return != ftrace_stub */ | ||
103 | beqid r5, end_graph_tracer; | ||
104 | nop; | ||
105 | |||
106 | lwi r6, r0, ftrace_graph_entry; | ||
107 | addik r5, r0, ftrace_graph_entry_stub; /* implemented in C */ | ||
108 | cmpu r5, r5, r6; /* ftrace_graph_entry != ftrace_graph_entry_stub */ | ||
109 | beqid r5, end_graph_tracer; | ||
110 | nop; | ||
111 | addik r5, r1, 120; /* MS: load parent addr */ | ||
112 | addik r6, r15, 0; /* MS: load current function addr */ | ||
113 | bralid r15, prepare_ftrace_return; | ||
114 | nop; | ||
115 | /* MS: graph was taken that's why - can jump over function trace */ | ||
116 | brid end; | ||
117 | nop; | ||
118 | end_graph_tracer: | ||
119 | #endif /* CONFIG_FUNCTION_GRAPH_TRACER */ | ||
99 | #ifndef CONFIG_DYNAMIC_FTRACE | 120 | #ifndef CONFIG_DYNAMIC_FTRACE |
100 | /* MS: test function trace if is taken or not */ | 121 | /* MS: test function trace if is taken or not */ |
101 | lwi r20, r0, ftrace_trace_function; | 122 | lwi r20, r0, ftrace_trace_function; |
@@ -121,3 +142,23 @@ end: | |||
121 | 142 | ||
122 | rtsd r15, 8; /* MS: jump back */ | 143 | rtsd r15, 8; /* MS: jump back */ |
123 | nop; | 144 | nop; |
145 | |||
146 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | ||
147 | ENTRY(return_to_handler) | ||
148 | nop; /* MS: just barrier for rtsd r15, 8 */ | ||
149 | nop; | ||
150 | SAVE_REGS | ||
151 | swi r15, r1, 0; | ||
152 | |||
153 | /* MS: find out returning address */ | ||
154 | bralid r15, ftrace_return_to_handler; | ||
155 | nop; | ||
156 | |||
157 | /* MS: return value from ftrace_return_to_handler is my returning addr | ||
158 | * must be before restore regs because I have to restore r3 content */ | ||
159 | addik r15, r3, 0; | ||
160 | RESTORE_REGS | ||
161 | |||
162 | rtsd r15, 8; /* MS: jump back */ | ||
163 | nop; | ||
164 | #endif /* CONFIG_FUNCTION_TRACER */ | ||