* [GIT PULL] tracing/core updates
@ 2009-10-13 7:38 Frederic Weisbecker
2009-10-13 7:38 ` [PATCH 1/3] ftrace: add kernel command line graph function filtering Frederic Weisbecker
` (3 more replies)
0 siblings, 4 replies; 10+ messages in thread
From: Frederic Weisbecker @ 2009-10-13 7:38 UTC (permalink / raw)
To: Ingo Molnar
Cc: LKML, Frederic Weisbecker, Stefan Assmann, Steven Rostedt,
Li Zefan
Ingo,
Please pull the tracing/core branch that can be found at
git://git.kernel.org/pub/scm/linux/kernel/git/frederic/random-tracing.git
tracing/core
Thanks.
Frederic Weisbecker (2):
tracing: Rename set_ftrace to set_bootup_ftrace
tracing: Remove unused ftrace_trace_addr helper
Stefan Assmann (1):
ftrace: add kernel command line graph function filtering
Documentation/kernel-parameters.txt | 7 +++++++
kernel/trace/ftrace.c | 34 ++++++++++++++++++++++++++++++++++
kernel/trace/trace.c | 4 ++--
kernel/trace/trace.h | 4 ----
4 files changed, 43 insertions(+), 6 deletions(-)
^ permalink raw reply [flat|nested] 10+ messages in thread* [PATCH 1/3] ftrace: add kernel command line graph function filtering 2009-10-13 7:38 [GIT PULL] tracing/core updates Frederic Weisbecker @ 2009-10-13 7:38 ` Frederic Weisbecker 2009-10-13 8:06 ` Li Zefan 2009-10-13 7:38 ` [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace Frederic Weisbecker ` (2 subsequent siblings) 3 siblings, 1 reply; 10+ messages in thread From: Frederic Weisbecker @ 2009-10-13 7:38 UTC (permalink / raw) To: Ingo Molnar Cc: LKML, Stefan Assmann, Steven Rostedt, Li Zefan, Frederic Weisbecker From: Stefan Assmann <sassmann@redhat.com> Add a command line parameter to allow limiting the function graphs that are traced on boot up from the given top-level callers , when ftrace=function_graph is specified. This patch adds the following command line option: ftrace_graph_filter=function-list Where function-list is a comma separated list of functions to filter. [fweisbec@gmail.com: picked the documentation changes from the v2 patch] Signed-off-by: Stefan Assmann <sassmann@redhat.com> Acked-by: Steven Rostedt <rostedt@goodmis.org> LKML-Reference: <4AD2DEB9.2@redhat.com> Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> --- Documentation/kernel-parameters.txt | 7 +++++++ kernel/trace/ftrace.c | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 0 deletions(-) diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index 6fa7292..1dc4b9c 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt @@ -778,6 +778,13 @@ and is between 256 and 4096 characters. It is defined in the file by the set_ftrace_notrace file in the debugfs tracing directory. + ftrace_graph_filter=[function-list] + [FTRACE] Limit the top level callers functions traced + by the function graph tracer at boot up. + function-list is a comma separated list of functions + that can be changed at run time by the + set_graph_function file in the debugfs tracing directory. + gamecon.map[2|3]= [HW,JOY] Multisystem joystick and NES/SNES/PSX pad support via parallel port (up to 5 devices per port) diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 9a72853..91283d4 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; ftrace_func_t __ftrace_trace_function __read_mostly = ftrace_stub; ftrace_func_t ftrace_pid_function __read_mostly = ftrace_stub; +#ifdef CONFIG_FUNCTION_GRAPH_TRACER +static int ftrace_set_func(unsigned long *array, int *idx, char *buffer); +#endif + static void ftrace_list_func(unsigned long ip, unsigned long parent_ip) { struct ftrace_ops *op = ftrace_list; @@ -2248,6 +2252,7 @@ void ftrace_set_notrace(unsigned char *buf, int len, int reset) #define FTRACE_FILTER_SIZE COMMAND_LINE_SIZE static char ftrace_notrace_buf[FTRACE_FILTER_SIZE] __initdata; static char ftrace_filter_buf[FTRACE_FILTER_SIZE] __initdata; +static char ftrace_graph_buf[FTRACE_FILTER_SIZE] __initdata; static int __init set_ftrace_notrace(char *str) { @@ -2263,6 +2268,31 @@ static int __init set_ftrace_filter(char *str) } __setup("ftrace_filter=", set_ftrace_filter); +#ifdef CONFIG_FUNCTION_GRAPH_TRACER +static int __init set_graph_function(char *str) +{ + strncpy(ftrace_graph_buf, str, FTRACE_FILTER_SIZE); + return 1; +} +__setup("ftrace_graph_filter=", set_graph_function); + +static void __init set_ftrace_early_graph(char *buf) +{ + int ret; + char *func; + + while (buf) { + func = strsep(&buf, ","); + /* we allow only one expression at a time */ + ret = ftrace_set_func(ftrace_graph_funcs, &ftrace_graph_count, + func); + if (ret) + printk(KERN_DEBUG "ftrace: function %s not " + "traceable\n", func); + } +} +#endif /* CONFIG_FUNCTION_GRAPH_TRACER */ + static void __init set_ftrace_early_filter(char *buf, int enable) { char *func; @@ -2279,6 +2309,10 @@ static void __init set_ftrace_early_filters(void) set_ftrace_early_filter(ftrace_filter_buf, 1); if (ftrace_notrace_buf[0]) set_ftrace_early_filter(ftrace_notrace_buf, 0); +#ifdef CONFIG_FUNCTION_GRAPH_TRACER + if (ftrace_graph_buf[0]) + set_ftrace_early_graph(ftrace_graph_buf); +#endif /* CONFIG_FUNCTION_GRAPH_TRACER */ } static int -- 1.6.2.3 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH 1/3] ftrace: add kernel command line graph function filtering 2009-10-13 7:38 ` [PATCH 1/3] ftrace: add kernel command line graph function filtering Frederic Weisbecker @ 2009-10-13 8:06 ` Li Zefan 2009-10-13 8:58 ` Frédéric Weisbecker 0 siblings, 1 reply; 10+ messages in thread From: Li Zefan @ 2009-10-13 8:06 UTC (permalink / raw) To: Frederic Weisbecker; +Cc: Ingo Molnar, LKML, Stefan Assmann, Steven Rostedt > +#ifdef CONFIG_FUNCTION_GRAPH_TRACER > +static int __init set_graph_function(char *str) > +{ > + strncpy(ftrace_graph_buf, str, FTRACE_FILTER_SIZE); should use strlcpy(). > + return 1; > +} ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 1/3] ftrace: add kernel command line graph function filtering 2009-10-13 8:06 ` Li Zefan @ 2009-10-13 8:58 ` Frédéric Weisbecker 0 siblings, 0 replies; 10+ messages in thread From: Frédéric Weisbecker @ 2009-10-13 8:58 UTC (permalink / raw) To: Li Zefan; +Cc: Ingo Molnar, LKML, Stefan Assmann, Steven Rostedt 2009/10/13 Li Zefan <lizf@cn.fujitsu.com>: >> +#ifdef CONFIG_FUNCTION_GRAPH_TRACER >> +static int __init set_graph_function(char *str) >> +{ >> + strncpy(ftrace_graph_buf, str, FTRACE_FILTER_SIZE); > > should use strlcpy(). > Right, I'll fix, thanks. ^ permalink raw reply [flat|nested] 10+ messages in thread
* [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace 2009-10-13 7:38 [GIT PULL] tracing/core updates Frederic Weisbecker 2009-10-13 7:38 ` [PATCH 1/3] ftrace: add kernel command line graph function filtering Frederic Weisbecker @ 2009-10-13 7:38 ` Frederic Weisbecker 2009-10-13 13:22 ` Steven Rostedt 2009-10-13 7:39 ` [PATCH 3/3] tracing: Remove unused ftrace_trace_addr helper Frederic Weisbecker 2009-10-13 10:04 ` [GIT PULL] tracing/core updates Ingo Molnar 3 siblings, 1 reply; 10+ messages in thread From: Frederic Weisbecker @ 2009-10-13 7:38 UTC (permalink / raw) To: Ingo Molnar; +Cc: LKML, Frederic Weisbecker, Steven Rostedt, Li Zefan Do this rename because set_ftrace is too much generic and not enough self-explainable as a name. Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Li Zefan <lizf@cn.fujitsu.com> --- kernel/trace/trace.c | 4 ++-- 1 files changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 4506826..866daf8 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -129,7 +129,7 @@ static int tracing_set_tracer(const char *buf); static char bootup_tracer_buf[MAX_TRACER_SIZE] __initdata; static char *default_bootup_tracer; -static int __init set_ftrace(char *str) +static int __init set_bootup_ftrace(char *str) { strncpy(bootup_tracer_buf, str, MAX_TRACER_SIZE); default_bootup_tracer = bootup_tracer_buf; @@ -137,7 +137,7 @@ static int __init set_ftrace(char *str) ring_buffer_expanded = 1; return 1; } -__setup("ftrace=", set_ftrace); +__setup("ftrace=", set_bootup_ftrace); static int __init set_ftrace_dump_on_oops(char *str) { -- 1.6.2.3 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace 2009-10-13 7:38 ` [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace Frederic Weisbecker @ 2009-10-13 13:22 ` Steven Rostedt 2009-10-13 13:35 ` Frederic Weisbecker 0 siblings, 1 reply; 10+ messages in thread From: Steven Rostedt @ 2009-10-13 13:22 UTC (permalink / raw) To: Frederic Weisbecker; +Cc: Ingo Molnar, LKML, Li Zefan On Tue, 2009-10-13 at 09:38 +0200, Frederic Weisbecker wrote: > Do this rename because set_ftrace is too much generic and not enough > self-explainable as a name. > > Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> > Cc: Steven Rostedt <rostedt@goodmis.org> > Cc: Li Zefan <lizf@cn.fujitsu.com> > --- > kernel/trace/trace.c | 4 ++-- > 1 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c > index 4506826..866daf8 100644 > --- a/kernel/trace/trace.c > +++ b/kernel/trace/trace.c > @@ -129,7 +129,7 @@ static int tracing_set_tracer(const char *buf); > static char bootup_tracer_buf[MAX_TRACER_SIZE] __initdata; > static char *default_bootup_tracer; > > -static int __init set_ftrace(char *str) > +static int __init set_bootup_ftrace(char *str) > { > strncpy(bootup_tracer_buf, str, MAX_TRACER_SIZE); > default_bootup_tracer = bootup_tracer_buf; > @@ -137,7 +137,7 @@ static int __init set_ftrace(char *str) > ring_buffer_expanded = 1; > return 1; > } > -__setup("ftrace=", set_ftrace); > +__setup("ftrace=", set_bootup_ftrace); Actually, it probably should be called, set_cmdline_ftrace. Since it came from the command line, and that is what is matching. -- Steve > > static int __init set_ftrace_dump_on_oops(char *str) > { ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace 2009-10-13 13:22 ` Steven Rostedt @ 2009-10-13 13:35 ` Frederic Weisbecker 2009-10-13 13:41 ` Steven Rostedt 0 siblings, 1 reply; 10+ messages in thread From: Frederic Weisbecker @ 2009-10-13 13:35 UTC (permalink / raw) To: rostedt; +Cc: Ingo Molnar, LKML, Li Zefan 2009/10/13 Steven Rostedt <rostedt@goodmis.org>: > On Tue, 2009-10-13 at 09:38 +0200, Frederic Weisbecker wrote: >> Do this rename because set_ftrace is too much generic and not enough >> self-explainable as a name. >> >> Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> >> Cc: Steven Rostedt <rostedt@goodmis.org> >> Cc: Li Zefan <lizf@cn.fujitsu.com> >> --- >> kernel/trace/trace.c | 4 ++-- >> 1 files changed, 2 insertions(+), 2 deletions(-) >> >> diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c >> index 4506826..866daf8 100644 >> --- a/kernel/trace/trace.c >> +++ b/kernel/trace/trace.c >> @@ -129,7 +129,7 @@ static int tracing_set_tracer(const char *buf); >> static char bootup_tracer_buf[MAX_TRACER_SIZE] __initdata; >> static char *default_bootup_tracer; >> >> -static int __init set_ftrace(char *str) >> +static int __init set_bootup_ftrace(char *str) >> { >> strncpy(bootup_tracer_buf, str, MAX_TRACER_SIZE); >> default_bootup_tracer = bootup_tracer_buf; >> @@ -137,7 +137,7 @@ static int __init set_ftrace(char *str) >> ring_buffer_expanded = 1; >> return 1; >> } >> -__setup("ftrace=", set_ftrace); >> +__setup("ftrace=", set_bootup_ftrace); > > Actually, it probably should be called, set_cmdline_ftrace. Since it > came from the command line, and that is what is matching. > > -- Steve No problem, I can change that in another request that also addresses Li's suggestion. ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace 2009-10-13 13:35 ` Frederic Weisbecker @ 2009-10-13 13:41 ` Steven Rostedt 0 siblings, 0 replies; 10+ messages in thread From: Steven Rostedt @ 2009-10-13 13:41 UTC (permalink / raw) To: Frederic Weisbecker; +Cc: Ingo Molnar, LKML, Li Zefan On Tue, 2009-10-13 at 15:35 +0200, Frederic Weisbecker wrote: > 2009/10/13 Steven Rostedt <rostedt@goodmis.org>: > >> -__setup("ftrace=", set_ftrace); > >> +__setup("ftrace=", set_bootup_ftrace); > > > > Actually, it probably should be called, set_cmdline_ftrace. Since it > > came from the command line, and that is what is matching. > > > > -- Steve > > No problem, I can change that in another request that also addresses > Li's suggestion. Yeah, I would label this as an extreme NON-critical change ;-) -- Steve ^ permalink raw reply [flat|nested] 10+ messages in thread
* [PATCH 3/3] tracing: Remove unused ftrace_trace_addr helper 2009-10-13 7:38 [GIT PULL] tracing/core updates Frederic Weisbecker 2009-10-13 7:38 ` [PATCH 1/3] ftrace: add kernel command line graph function filtering Frederic Weisbecker 2009-10-13 7:38 ` [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace Frederic Weisbecker @ 2009-10-13 7:39 ` Frederic Weisbecker 2009-10-13 10:04 ` [GIT PULL] tracing/core updates Ingo Molnar 3 siblings, 0 replies; 10+ messages in thread From: Frederic Weisbecker @ 2009-10-13 7:39 UTC (permalink / raw) To: Ingo Molnar; +Cc: LKML, Frederic Weisbecker, Steven Rostedt, Li Zefan Remove the ftrace_trace_addr() function as only its off-case is implemented and there are no users of it currently. But we keep ftrace_graph_addr() off-case, in case someone come to use the function graph tracer to profit from top-level callers filtering. Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Li Zefan <lizf@cn.fujitsu.com> --- kernel/trace/trace.h | 4 ---- 1 files changed, 0 insertions(+), 4 deletions(-) diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 365fb19..f22a7ac 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h @@ -483,10 +483,6 @@ static inline int ftrace_graph_addr(unsigned long addr) return 0; } #else -static inline int ftrace_trace_addr(unsigned long addr) -{ - return 1; -} static inline int ftrace_graph_addr(unsigned long addr) { return 1; -- 1.6.2.3 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [GIT PULL] tracing/core updates 2009-10-13 7:38 [GIT PULL] tracing/core updates Frederic Weisbecker ` (2 preceding siblings ...) 2009-10-13 7:39 ` [PATCH 3/3] tracing: Remove unused ftrace_trace_addr helper Frederic Weisbecker @ 2009-10-13 10:04 ` Ingo Molnar 3 siblings, 0 replies; 10+ messages in thread From: Ingo Molnar @ 2009-10-13 10:04 UTC (permalink / raw) To: Frederic Weisbecker; +Cc: LKML, Stefan Assmann, Steven Rostedt, Li Zefan * Frederic Weisbecker <fweisbec@gmail.com> wrote: > Ingo, > > Please pull the tracing/core branch that can be found at > > git://git.kernel.org/pub/scm/linux/kernel/git/frederic/random-tracing.git > tracing/core > > Thanks. > > Frederic Weisbecker (2): > tracing: Rename set_ftrace to set_bootup_ftrace > tracing: Remove unused ftrace_trace_addr helper > > Stefan Assmann (1): > ftrace: add kernel command line graph function filtering > > Documentation/kernel-parameters.txt | 7 +++++++ > kernel/trace/ftrace.c | 34 ++++++++++++++++++++++++++++++++++ > kernel/trace/trace.c | 4 ++-- > kernel/trace/trace.h | 4 ---- > 4 files changed, 43 insertions(+), 6 deletions(-) Pulled, thanks Frederic! Ingo ^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2009-10-13 13:43 UTC | newest] Thread overview: 10+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2009-10-13 7:38 [GIT PULL] tracing/core updates Frederic Weisbecker 2009-10-13 7:38 ` [PATCH 1/3] ftrace: add kernel command line graph function filtering Frederic Weisbecker 2009-10-13 8:06 ` Li Zefan 2009-10-13 8:58 ` Frédéric Weisbecker 2009-10-13 7:38 ` [PATCH 2/3] tracing: Rename set_ftrace to set_bootup_ftrace Frederic Weisbecker 2009-10-13 13:22 ` Steven Rostedt 2009-10-13 13:35 ` Frederic Weisbecker 2009-10-13 13:41 ` Steven Rostedt 2009-10-13 7:39 ` [PATCH 3/3] tracing: Remove unused ftrace_trace_addr helper Frederic Weisbecker 2009-10-13 10:04 ` [GIT PULL] tracing/core updates Ingo Molnar
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox