@@ -1011,7 +1011,7 @@ static const struct file_operations ftrace_profile_fops = {
};
/* used to initialize the real stat files */
-static struct tracer_stat function_stats __initdata = {
+static struct tracer_stat function_stats = {
.name = "functions",
.stat_start = function_stat_start,
.stat_next = function_stat_next,
@@ -1020,7 +1020,7 @@ static struct tracer_stat function_stats __initdata = {
.stat_show = function_stat_show
};
-static __init void ftrace_profile_tracefs(struct dentry *d_tracer)
+static void ftrace_profile_tracefs(struct dentry *d_tracer)
{
struct ftrace_profile_stat *stat;
struct dentry *entry;
@@ -1061,7 +1061,7 @@ static __init void ftrace_profile_tracefs(struct dentry *d_tracer)
}
#else /* CONFIG_FUNCTION_PROFILER */
-static __init void ftrace_profile_tracefs(struct dentry *d_tracer)
+static void ftrace_profile_tracefs(struct dentry *d_tracer)
{
}
#endif /* CONFIG_FUNCTION_PROFILER */
@@ -4797,7 +4797,7 @@ void ftrace_destroy_filter_files(struct ftrace_ops *ops)
mutex_unlock(&ftrace_lock);
}
-static __init int ftrace_init_dyn_tracefs(struct dentry *d_tracer)
+static int ftrace_init_dyn_tracefs(struct dentry *d_tracer)
{
trace_create_file("available_filter_functions", 0444,
Not marking ftrace_init_tracefs() as __init causes a link time warning: WARNING: vmlinux.o(.text+0xf5fcc): Section mismatch in reference from the function ftrace_init_tracefs() to the (unknown reference) .init.data:(unknown) The problem here is that ftrace_init_tracefs() now gets called by init_tracer_tracefs(), which cannot be __init because it is called post init-time from instance_mkdir(). The function calls to the init-time ftrace_init_dyn_tracefs() and ftrace_profile_tracefs() functions apparently only happen for the initial call to ftrace_init_tracefs(), so we could safely ignore the warning, but at the same time, it all gets inlined anyway and we may as well remove the annotations. The alternative would be restructuring the code so we only call trace_create_file() from init_tracer_tracefs(), but not the other init-time functions. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Fixes: 345ddcc882d8 ("ftrace: Have set_ftrace_pid use the bitmap like events do") --- kernel/trace/ftrace.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) -- 2.9.0