]> git.ipfire.org Git - thirdparty/kernel/stable.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)
commit562e14f72292249e52e6346a9e3a30be652b0cf6
tree25e276f9e975255e922f28d659aebe6de67d8497
parent518049d9d3e25dcd7be6e3d728e86f292ad0c922
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