aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/ftrace.h
diff options
context:
space:
mode:
authorJessica Yu <jeyu@redhat.com>2016-02-16 17:32:33 -0500
committerJiri Kosina <jkosina@suse.cz>2016-02-17 16:14:06 -0500
commit7dcd182bec271ab341b05b66b6006995795fc0e7 (patch)
treeb2850092d0b57e9c33bb8743ca5053ca6404552d /include/linux/ftrace.h
parent383bf44d1a8b18de5c26ec2a48c6822681b50984 (diff)
ftrace/module: remove ftrace module notifier
Remove the ftrace module notifier in favor of directly calling ftrace_module_enable() and ftrace_release_mod() in the module loader. Hard-coding the function calls directly in the module loader removes dependence on the module notifier call chain and provides better visibility and control over what gets called when, which is important to kernel utilities such as livepatch. This fixes a notifier ordering issue in which the ftrace module notifier (and hence ftrace_module_enable()) for coming modules was being called after klp_module_notify(), which caused livepatch modules to initialize incorrectly. This patch removes dependence on the module notifier call chain in favor of hard coding the corresponding function calls in the module loader. This ensures that ftrace and livepatch code get called in the correct order on patch module load and unload. Fixes: 5156dca34a3e ("ftrace: Fix the race between ftrace and insmod") Signed-off-by: Jessica Yu <jeyu@redhat.com> Reviewed-by: Steven Rostedt <rostedt@goodmis.org> Reviewed-by: Petr Mladek <pmladek@suse.cz> Acked-by: Rusty Russell <rusty@rustcorp.com.au> Reviewed-by: Josh Poimboeuf <jpoimboe@redhat.com> Reviewed-by: Miroslav Benes <mbenes@suse.cz> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'include/linux/ftrace.h')
-rw-r--r--include/linux/ftrace.h6
1 files changed, 4 insertions, 2 deletions
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h
index 0639dcc98195..76dc15e171eb 100644
--- a/include/linux/ftrace.h
+++ b/include/linux/ftrace.h
@@ -604,6 +604,7 @@ extern int ftrace_arch_read_dyn_info(char *buf, int size);
604 604
605extern int skip_trace(unsigned long ip); 605extern int skip_trace(unsigned long ip);
606extern void ftrace_module_init(struct module *mod); 606extern void ftrace_module_init(struct module *mod);
607extern void ftrace_module_enable(struct module *mod);
607extern void ftrace_release_mod(struct module *mod); 608extern void ftrace_release_mod(struct module *mod);
608 609
609extern void ftrace_disable_daemon(void); 610extern void ftrace_disable_daemon(void);
@@ -613,8 +614,9 @@ static inline int skip_trace(unsigned long ip) { return 0; }
613static inline int ftrace_force_update(void) { return 0; } 614static inline int ftrace_force_update(void) { return 0; }
614static inline void ftrace_disable_daemon(void) { } 615static inline void ftrace_disable_daemon(void) { }
615static inline void ftrace_enable_daemon(void) { } 616static inline void ftrace_enable_daemon(void) { }
616static inline void ftrace_release_mod(struct module *mod) {} 617static inline void ftrace_module_init(struct module *mod) { }
617static inline void ftrace_module_init(struct module *mod) {} 618static inline void ftrace_module_enable(struct module *mod) { }
619static inline void ftrace_release_mod(struct module *mod) { }
618static inline __init int register_ftrace_command(struct ftrace_func_command *cmd) 620static inline __init int register_ftrace_command(struct ftrace_func_command *cmd)
619{ 621{
620 return -EINVAL; 622 return -EINVAL;