diff options
-rw-r--r-- | arch/arm/Kconfig.debug | 5 | ||||
-rw-r--r-- | arch/arm/kernel/armksyms.c | 2 | ||||
-rw-r--r-- | arch/arm/kernel/entry-common.S | 14 | ||||
-rw-r--r-- | kernel/trace/Kconfig | 2 |
4 files changed, 22 insertions, 1 deletions
diff --git a/arch/arm/Kconfig.debug b/arch/arm/Kconfig.debug index 91344af75f39..4dbce538fec4 100644 --- a/arch/arm/Kconfig.debug +++ b/arch/arm/Kconfig.debug | |||
@@ -27,6 +27,11 @@ config ARM_UNWIND | |||
27 | the performance is not affected. Currently, this feature | 27 | the performance is not affected. Currently, this feature |
28 | only works with EABI compilers. If unsure say Y. | 28 | only works with EABI compilers. If unsure say Y. |
29 | 29 | ||
30 | config OLD_MCOUNT | ||
31 | bool | ||
32 | depends on FUNCTION_TRACER && FRAME_POINTER | ||
33 | default y | ||
34 | |||
30 | config DEBUG_USER | 35 | config DEBUG_USER |
31 | bool "Verbose user fault messages" | 36 | bool "Verbose user fault messages" |
32 | help | 37 | help |
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 | ||
168 | EXPORT_SYMBOL(mcount); | 169 | EXPORT_SYMBOL(mcount); |
170 | #endif | ||
169 | EXPORT_SYMBOL(__gnu_mcount_nc); | 171 | EXPORT_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 |
132 | ENTRY(mcount) | 139 | ENTRY(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 | */ | ||
176 | ENTRY(mcount) | 189 | ENTRY(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 | ||
diff --git a/kernel/trace/Kconfig b/kernel/trace/Kconfig index 538501c6ea50..6329d063b5e4 100644 --- a/kernel/trace/Kconfig +++ b/kernel/trace/Kconfig | |||
@@ -121,7 +121,7 @@ if FTRACE | |||
121 | config FUNCTION_TRACER | 121 | config FUNCTION_TRACER |
122 | bool "Kernel Function Tracer" | 122 | bool "Kernel Function Tracer" |
123 | depends on HAVE_FUNCTION_TRACER | 123 | depends on HAVE_FUNCTION_TRACER |
124 | select FRAME_POINTER | 124 | select FRAME_POINTER if (!ARM_UNWIND) |
125 | select KALLSYMS | 125 | select KALLSYMS |
126 | select GENERIC_TRACER | 126 | select GENERIC_TRACER |
127 | select CONTEXT_SWITCH_TRACER | 127 | select CONTEXT_SWITCH_TRACER |