ftrace: remove old pointers to mcount
authorSteven Rostedt <rostedt@goodmis.org>
Fri, 15 Aug 2008 02:47:19 +0000 (22:47 -0400)
committerIngo Molnar <mingo@elte.hu>
Tue, 14 Oct 2008 08:35:12 +0000 (10:35 +0200)
commitfed1939c64d2288938fdc1c367d49082da65e195
treea4592352d28efcfe82379c71d061b9127e49a115
parent28614889bcb2558a47d02d52394b7fd9795a9547
ftrace: remove old pointers to mcount

When a mcount pointer is recorded into a table, it is used to add or
remove calls to mcount (replacing them with nops). If the code is removed
via removing a module, the pointers still exist.  At modifying the code
a check is always made to make sure the code being replaced is the code
expected. In-other-words, the code being replaced is compared to what
it is expected to be before being replaced.

There is a very small chance that the code being replaced just happens
to look like code that calls mcount (very small since the call to mcount
is relative). To remove this chance, this patch adds ftrace_release to
allow module unloading to remove the pointers to mcount within the module.

Another change for init calls is made to not trace calls marked with
__init. The tracing can not be started until after init is done anyway.

Signed-off-by: Steven Rostedt <srostedt@redhat.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
include/linux/ftrace.h
include/linux/init.h
kernel/module.c
kernel/trace/ftrace.c