diff options
author | Steven Rostedt <rostedt@goodmis.org> | 2008-08-14 22:47:19 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-10-14 04:35:12 -0400 |
commit | fed1939c64d2288938fdc1c367d49082da65e195 (patch) | |
tree | a4592352d28efcfe82379c71d061b9127e49a115 /include/linux | |
parent | 28614889bcb2558a47d02d52394b7fd9795a9547 (diff) |
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>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/ftrace.h | 2 | ||||
-rw-r--r-- | include/linux/init.h | 2 |
2 files changed, 3 insertions, 1 deletions
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index 4936489f9ed8..6b232a2460c0 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h | |||
@@ -165,10 +165,12 @@ ftrace_special(unsigned long arg1, unsigned long arg2, unsigned long arg3) { } | |||
165 | #ifdef CONFIG_FTRACE_MCOUNT_RECORD | 165 | #ifdef CONFIG_FTRACE_MCOUNT_RECORD |
166 | extern void ftrace_init(void); | 166 | extern void ftrace_init(void); |
167 | extern void ftrace_init_module(unsigned long *start, unsigned long *end); | 167 | extern void ftrace_init_module(unsigned long *start, unsigned long *end); |
168 | extern void ftrace_release(void *start, unsigned long size); | ||
168 | #else | 169 | #else |
169 | static inline void ftrace_init(void) { } | 170 | static inline void ftrace_init(void) { } |
170 | static inline void | 171 | static inline void |
171 | ftrace_init_module(unsigned long *start, unsigned long *end) { } | 172 | ftrace_init_module(unsigned long *start, unsigned long *end) { } |
173 | static inline void ftrace_release(void *start, unsigned long size) { } | ||
172 | #endif | 174 | #endif |
173 | 175 | ||
174 | #endif /* _LINUX_FTRACE_H */ | 176 | #endif /* _LINUX_FTRACE_H */ |
diff --git a/include/linux/init.h b/include/linux/init.h index 93538b696e3d..27f61f6b3cb9 100644 --- a/include/linux/init.h +++ b/include/linux/init.h | |||
@@ -40,7 +40,7 @@ | |||
40 | 40 | ||
41 | /* These are for everybody (although not all archs will actually | 41 | /* These are for everybody (although not all archs will actually |
42 | discard it in modules) */ | 42 | discard it in modules) */ |
43 | #define __init __section(.init.text) __cold | 43 | #define __init __section(.init.text) __cold notrace |
44 | #define __initdata __section(.init.data) | 44 | #define __initdata __section(.init.data) |
45 | #define __initconst __section(.init.rodata) | 45 | #define __initconst __section(.init.rodata) |
46 | #define __exitdata __section(.exit.data) | 46 | #define __exitdata __section(.exit.data) |