ftrace: Add a ftrace_free_mem() function for modules to use
authorSteven Rostedt (VMware) <rostedt@goodmis.org>
Tue, 20 Jun 2017 14:44:58 +0000 (10:44 -0400)
committerSteven Rostedt (VMware) <rostedt@goodmis.org>
Wed, 4 Oct 2017 18:20:52 +0000 (14:20 -0400)
In order to be able to trace module init functions, the module code needs to
tell ftrace what is being freed when the init sections are freed. Use the
code that the main init calls to tell ftrace to free the main init sections.
This requires passing in a start and end address to free.

Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
include/linux/ftrace.h
kernel/trace/ftrace.c

index 2e028854bac779c1282b5c7201904ef7194f89a0..47fc404ad23300227be425730ff623e56bbc6b1c 100644 (file)
@@ -151,8 +151,10 @@ struct ftrace_ops_hash {
 };
 
 void ftrace_free_init_mem(void);
+void ftrace_free_mem(void *start, void *end);
 #else
 static inline void ftrace_free_init_mem(void) { }
+static inline void ftrace_free_mem(void *start, void *end) { }
 #endif
 
 /*
index 6abfafd7f173c49ab60221768654a7b08f7d7f22..84cb5928665ae9c6ab6d62ee32eafe14f6d89452 100644 (file)
@@ -5868,10 +5868,10 @@ void ftrace_module_init(struct module *mod)
 }
 #endif /* CONFIG_MODULES */
 
-void __init ftrace_free_init_mem(void)
+void ftrace_free_mem(void *start_ptr, void *end_ptr)
 {
-       unsigned long start = (unsigned long)(&__init_begin);
-       unsigned long end = (unsigned long)(&__init_end);
+       unsigned long start = (unsigned long)(start_ptr);
+       unsigned long end = (unsigned long)(end_ptr);
        struct ftrace_page **last_pg = &ftrace_pages_start;
        struct ftrace_page *pg;
        struct dyn_ftrace *rec;
@@ -5913,6 +5913,14 @@ void __init ftrace_free_init_mem(void)
        mutex_unlock(&ftrace_lock);
 }
 
+void __init ftrace_free_init_mem(void)
+{
+       void *start = (void *)(&__init_begin);
+       void *end = (void *)(&__init_end);
+
+       ftrace_free_mem(start, end);
+}
+
 void __init ftrace_init(void)
 {
        extern unsigned long __start_mcount_loc[];