提交 d5e47505 编写于 作者: M Miroslav Benes 提交者: Steven Rostedt (VMware)

ftrace: Free the trampoline when ftrace_startup() fails

Commit fc0ea795 ("ftrace: Add symbols for ftrace trampolines")
missed to remove ops from new ftrace_ops_trampoline_list in
ftrace_startup() if ftrace_hash_ipmodify_enable() fails there. It may
lead to BUG if such ops come from a module which may be removed.

Moreover, the trampoline itself is not freed in this case.

Fix it by calling ftrace_trampoline_free() during the rollback.

Link: https://lkml.kernel.org/r/20200831122631.28057-1-mbenes@suse.cz

Fixes: fc0ea795 ("ftrace: Add symbols for ftrace trampolines")
Fixes: f8b8be8a ("ftrace, kprobes: Support IPMODIFY flag to find IP modify conflict")
Signed-off-by: NMiroslav Benes <mbenes@suse.cz>
Signed-off-by: NSteven Rostedt (VMware) <rostedt@goodmis.org>
上级 3031313e
...@@ -2862,6 +2862,8 @@ int ftrace_startup(struct ftrace_ops *ops, int command) ...@@ -2862,6 +2862,8 @@ int ftrace_startup(struct ftrace_ops *ops, int command)
__unregister_ftrace_function(ops); __unregister_ftrace_function(ops);
ftrace_start_up--; ftrace_start_up--;
ops->flags &= ~FTRACE_OPS_FL_ENABLED; ops->flags &= ~FTRACE_OPS_FL_ENABLED;
if (ops->flags & FTRACE_OPS_FL_DYNAMIC)
ftrace_trampoline_free(ops);
return ret; return ret;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册