]> git.baikalelectronics.ru Git - kernel.git/commit
ftrace/x86: Remove mcount support
authorSteven Rostedt (VMware) <rostedt@goodmis.org>
Thu, 9 May 2019 19:32:05 +0000 (15:32 -0400)
committerSteven Rostedt (VMware) <rostedt@goodmis.org>
Fri, 10 May 2019 16:33:09 +0000 (12:33 -0400)
commit3b611bee355da3eadfd0a9d80d000eb22da23113
tree25e276f9e975255e922f28d659aebe6de67d8497
parent277e02b437fd8da3563dea340697b04e76550094
ftrace/x86: Remove mcount support

There's two methods of enabling function tracing in Linux on x86. One is
with just "gcc -pg" and the other is "gcc -pg -mfentry". The former will use
calls to a special function "mcount" after the frame is set up in all C
functions. The latter will add calls to a special function called "fentry"
as the very first instruction of all C functions.

At compile time, there is a check to see if gcc supports, -mfentry, and if
it does, it will use that, because it is more versatile and less error prone
for function tracing.

Starting with v4.19, the minimum gcc supported to build the Linux kernel,
was raised to version 4.6. That also happens to be the first gcc version to
support -mfentry. Since on x86, using gcc versions from 4.6 and beyond will
unconditionally enable the -mfentry, it will no longer use mcount as the
method for inserting calls into the C functions of the kernel. This means
that there is no point in continuing to maintain mcount in x86.

Remove support for using mcount. This makes the code less complex, and will
also allow it to be simplified in the future.

Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Acked-by: Jiri Kosina <jkosina@suse.cz>
Acked-by: Josh Poimboeuf <jpoimboe@redhat.com>
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
arch/x86/include/asm/ftrace.h
arch/x86/include/asm/livepatch.h
arch/x86/kernel/ftrace_32.S
arch/x86/kernel/ftrace_64.S