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 |
