x86/ftrace: Make non direct case the default in ftrace_regs_caller
authorSteven Rostedt (VMware) <rostedt@goodmis.org>
Wed, 22 Apr 2020 16:25:40 +0000 (12:25 -0400)
committerSteven Rostedt (VMware) <rostedt@goodmis.org>
Mon, 29 Jun 2020 15:42:47 +0000 (11:42 -0400)
commit0b4f8ddc0cc235f30431ed5c7d533b24e995d267
tree96262e746226b79cdc14dce39c880d33f8c066c8
parentc791cc4b1feb881b3644c059dba5464b076bf592
x86/ftrace: Make non direct case the default in ftrace_regs_caller

If a direct function is hooked along with one of the ftrace registered
functions, then the ftrace_regs_caller is attached to the function that
shares the direct hook as well as the ftrace hook. The ftrace_regs_caller
will call ftrace_ops_list_func() that iterates through all the registered
ftrace callbacks, and if there's a direct callback attached to that
function, the direct ftrace_ops callback is called to notify that
ftrace_regs_caller to return to the direct caller instead of going back to
the function that called it.

But this is a very uncommon case. Currently, the code has it as the default
case. Modify ftrace_regs_caller to make the default case (the non jump) to
just return normally, and have the jump to the handling of the direct
caller.

Link: http://lkml.kernel.org/r/20200422162750.350373278@goodmis.org
Cc: Peter Zijlstra <peterz@infradead.org>
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
arch/x86/kernel/ftrace_64.S