aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace/ftrace.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/trace/ftrace.c')
-rw-r--r--kernel/trace/ftrace.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c
index 9a72853a8f0a..91283d40821e 100644
--- a/kernel/trace/ftrace.c
+++ b/kernel/trace/ftrace.c
@@ -78,6 +78,10 @@ ftrace_func_t ftrace_trace_function __read_mostly = ftrace_stub;
78ftrace_func_t __ftrace_trace_function __read_mostly = ftrace_stub; 78ftrace_func_t __ftrace_trace_function __read_mostly = ftrace_stub;
79ftrace_func_t ftrace_pid_function __read_mostly = ftrace_stub; 79ftrace_func_t ftrace_pid_function __read_mostly = ftrace_stub;
80 80
81#ifdef CONFIG_FUNCTION_GRAPH_TRACER
82static int ftrace_set_func(unsigned long *array, int *idx, char *buffer);
83#endif
84
81static void ftrace_list_func(unsigned long ip, unsigned long parent_ip) 85static void ftrace_list_func(unsigned long ip, unsigned long parent_ip)
82{ 86{
83 struct ftrace_ops *op = ftrace_list; 87 struct ftrace_ops *op = ftrace_list;
@@ -2248,6 +2252,7 @@ void ftrace_set_notrace(unsigned char *buf, int len, int reset)
2248#define FTRACE_FILTER_SIZE COMMAND_LINE_SIZE 2252#define FTRACE_FILTER_SIZE COMMAND_LINE_SIZE
2249static char ftrace_notrace_buf[FTRACE_FILTER_SIZE] __initdata; 2253static char ftrace_notrace_buf[FTRACE_FILTER_SIZE] __initdata;
2250static char ftrace_filter_buf[FTRACE_FILTER_SIZE] __initdata; 2254static char ftrace_filter_buf[FTRACE_FILTER_SIZE] __initdata;
2255static char ftrace_graph_buf[FTRACE_FILTER_SIZE] __initdata;
2251 2256
2252static int __init set_ftrace_notrace(char *str) 2257static int __init set_ftrace_notrace(char *str)
2253{ 2258{
@@ -2263,6 +2268,31 @@ static int __init set_ftrace_filter(char *str)
2263} 2268}
2264__setup("ftrace_filter=", set_ftrace_filter); 2269__setup("ftrace_filter=", set_ftrace_filter);
2265 2270
2271#ifdef CONFIG_FUNCTION_GRAPH_TRACER
2272static int __init set_graph_function(char *str)
2273{
2274 strncpy(ftrace_graph_buf, str, FTRACE_FILTER_SIZE);
2275 return 1;
2276}
2277__setup("ftrace_graph_filter=", set_graph_function);
2278
2279static void __init set_ftrace_early_graph(char *buf)
2280{
2281 int ret;
2282 char *func;
2283
2284 while (buf) {
2285 func = strsep(&buf, ",");
2286 /* we allow only one expression at a time */
2287 ret = ftrace_set_func(ftrace_graph_funcs, &ftrace_graph_count,
2288 func);
2289 if (ret)
2290 printk(KERN_DEBUG "ftrace: function %s not "
2291 "traceable\n", func);
2292 }
2293}
2294#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
2295
2266static void __init set_ftrace_early_filter(char *buf, int enable) 2296static void __init set_ftrace_early_filter(char *buf, int enable)
2267{ 2297{
2268 char *func; 2298 char *func;
@@ -2279,6 +2309,10 @@ static void __init set_ftrace_early_filters(void)
2279 set_ftrace_early_filter(ftrace_filter_buf, 1); 2309 set_ftrace_early_filter(ftrace_filter_buf, 1);
2280 if (ftrace_notrace_buf[0]) 2310 if (ftrace_notrace_buf[0])
2281 set_ftrace_early_filter(ftrace_notrace_buf, 0); 2311 set_ftrace_early_filter(ftrace_notrace_buf, 0);
2312#ifdef CONFIG_FUNCTION_GRAPH_TRACER
2313 if (ftrace_graph_buf[0])
2314 set_ftrace_early_graph(ftrace_graph_buf);
2315#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
2282} 2316}
2283 2317
2284static int 2318static int