aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/kernel
diff options
context:
space:
mode:
authorRabin Vincent <rabin@rab.in>2010-08-10 14:32:37 -0400
committerRussell King <rmk+kernel@arm.linux.org.uk>2010-09-02 10:24:53 -0400
commit09bfafac3e237415cc4b6adde49f9f28b3a42659 (patch)
tree980006ad889a1395140dba2a3718ead537975df3 /arch/arm/kernel
parent7e9501fdecdee8151938e624b41978307cadddd2 (diff)
ARM: 6314/1: ftrace: allow build without frame pointers on ARM
With a new enough GCC, ARM function tracing can be supported without the need for frame pointers. This is essential for Thumb-2 support, since frame pointers aren't available then. Acked-by: Catalin Marinas <catalin.marinas@arm.com> Acked-by: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Rabin Vincent <rabin@rab.in> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/kernel')
-rw-r--r--arch/arm/kernel/armksyms.c2
-rw-r--r--arch/arm/kernel/entry-common.S14
2 files changed, 16 insertions, 0 deletions
diff --git a/arch/arm/kernel/armksyms.c b/arch/arm/kernel/armksyms.c
index 8214bfebfaca..e5e1e5387678 100644
--- a/arch/arm/kernel/armksyms.c
+++ b/arch/arm/kernel/armksyms.c
@@ -165,6 +165,8 @@ EXPORT_SYMBOL(_find_next_bit_be);
165#endif 165#endif
166 166
167#ifdef CONFIG_FUNCTION_TRACER 167#ifdef CONFIG_FUNCTION_TRACER
168#ifdef CONFIG_OLD_MCOUNT
168EXPORT_SYMBOL(mcount); 169EXPORT_SYMBOL(mcount);
170#endif
169EXPORT_SYMBOL(__gnu_mcount_nc); 171EXPORT_SYMBOL(__gnu_mcount_nc);
170#endif 172#endif
diff --git a/arch/arm/kernel/entry-common.S b/arch/arm/kernel/entry-common.S
index f05a35a59694..6805a7216bf8 100644
--- a/arch/arm/kernel/entry-common.S
+++ b/arch/arm/kernel/entry-common.S
@@ -128,6 +128,13 @@ ENDPROC(ret_from_fork)
128 * allows it to be clobbered in subroutines and doesn't use it to hold 128 * allows it to be clobbered in subroutines and doesn't use it to hold
129 * parameters.) 129 * parameters.)
130 */ 130 */
131
132#ifndef CONFIG_OLD_MCOUNT
133#if (__GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 4))
134#error Ftrace requires CONFIG_FRAME_POINTER=y with GCC older than 4.4.0.
135#endif
136#endif
137
131#ifdef CONFIG_DYNAMIC_FTRACE 138#ifdef CONFIG_DYNAMIC_FTRACE
132ENTRY(mcount) 139ENTRY(mcount)
133 stmdb sp!, {r0-r3, lr} 140 stmdb sp!, {r0-r3, lr}
@@ -173,6 +180,12 @@ gnu_trace:
173 ldmia sp!, {r0-r3, ip, lr} 180 ldmia sp!, {r0-r3, ip, lr}
174 mov pc, ip 181 mov pc, ip
175 182
183#ifdef CONFIG_OLD_MCOUNT
184/*
185 * This is under an ifdef in order to force link-time errors for people trying
186 * to build with !FRAME_POINTER with a GCC which doesn't use the new-style
187 * mcount.
188 */
176ENTRY(mcount) 189ENTRY(mcount)
177 stmdb sp!, {r0-r3, lr} 190 stmdb sp!, {r0-r3, lr}
178 ldr r0, =ftrace_trace_function 191 ldr r0, =ftrace_trace_function
@@ -191,6 +204,7 @@ trace:
191 mov pc, r2 204 mov pc, r2
192 ldr lr, [fp, #-4] @ restore lr 205 ldr lr, [fp, #-4] @ restore lr
193 ldmia sp!, {r0-r3, pc} 206 ldmia sp!, {r0-r3, pc}
207#endif
194 208
195#endif /* CONFIG_DYNAMIC_FTRACE */ 209#endif /* CONFIG_DYNAMIC_FTRACE */
196 210