ftrace: Move toplevel init out of ftrace_init_tracefs()
Commit345ddcc882
("ftrace: Have set_ftrace_pid use the bitmap like events do") placed ftrace_init_tracefs into the instance creation, and encapsulated the top level updating with an if conditional, as the top level only gets updated at boot up. Unfortunately, this triggers section mismatch errors as the init functions are called from a function that can be called later, and the section mismatch logic is unaware of the if conditional that would prevent it from happening at run time. To make everyone happy, create a separate ftrace_init_tracefs_toplevel() routine that only gets called by init functions, and this will be what calls other init functions for the toplevel directory. Link: http://lkml.kernel.org/r/20160704102139.19cbc0d9@gandalf.local.home Reported-by: kbuild test robot <fengguang.wu@intel.com> Reported-by: Arnd Bergmann <arnd@arndb.de> Fixes:345ddcc882
("ftrace: Have set_ftrace_pid use the bitmap like events do") Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:

committed by
Steven Rostedt

parent
7fa8b7171a
commit
501c237525
@@ -5539,16 +5539,20 @@ static const struct file_operations ftrace_pid_fops = {
|
||||
|
||||
void ftrace_init_tracefs(struct trace_array *tr, struct dentry *d_tracer)
|
||||
{
|
||||
/* Only the top level directory has the dyn_tracefs and profile */
|
||||
if (tr->flags & TRACE_ARRAY_FL_GLOBAL) {
|
||||
ftrace_init_dyn_tracefs(d_tracer);
|
||||
ftrace_profile_tracefs(d_tracer);
|
||||
}
|
||||
|
||||
trace_create_file("set_ftrace_pid", 0644, d_tracer,
|
||||
tr, &ftrace_pid_fops);
|
||||
}
|
||||
|
||||
void __init ftrace_init_tracefs_toplevel(struct trace_array *tr,
|
||||
struct dentry *d_tracer)
|
||||
{
|
||||
/* Only the top level directory has the dyn_tracefs and profile */
|
||||
WARN_ON(!(tr->flags & TRACE_ARRAY_FL_GLOBAL));
|
||||
|
||||
ftrace_init_dyn_tracefs(d_tracer);
|
||||
ftrace_profile_tracefs(d_tracer);
|
||||
}
|
||||
|
||||
/**
|
||||
* ftrace_kill - kill ftrace
|
||||
*
|
||||
|
Reference in New Issue
Block a user