[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20230112185925.5a51843e@gandalf.local.home>
Date:   Thu, 12 Jan 2023 18:59:25 -0500
From:   Steven Rostedt <rostedt@...dmis.org>
To:     Ross Zwisler <zwisler@...gle.com>
Cc:     linux-kernel@...r.kernel.org, linux-trace-kernel@...r.kernel.org,
        Masami Hiramatsu <mhiramat@...nel.org>,
        Andrew Morton <akpm@...ux-foundation.org>
Subject: Re: [PATCH 1/4] tracing: Add creation of instances at boot command
 line
On Thu, 12 Jan 2023 16:24:17 -0700
Ross Zwisler <zwisler@...gle.com> wrote:
> On Wed, Jan 11, 2023 at 09:56:37AM -0500, Steven Rostedt wrote:
> > From: "Steven Rostedt (Google)" <rostedt@...dmis.org>
> > 
> > Add kernel command line to add tracing instances. This only creates
> > instances at boot but still does not enable any events to them. Later
> > changes will extend this command line to add enabling of events, filters,
> > and triggers. As well as possibly redirecting trace_printk()!
> > 
> > Signed-off-by: Steven Rostedt (Google) <rostedt@...dmis.org>
> > ---
> >  .../admin-guide/kernel-parameters.txt         |  6 +++
> >  kernel/trace/trace.c                          | 51 +++++++++++++++++++
> >  2 files changed, 57 insertions(+)
> > 
> > diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
> > index 6cfa6e3996cf..cec486217ccc 100644
> > --- a/Documentation/admin-guide/kernel-parameters.txt
> > +++ b/Documentation/admin-guide/kernel-parameters.txt
> > @@ -6272,6 +6272,12 @@
> >  			comma-separated list of trace events to enable. See
> >  			also Documentation/trace/events.rst
> >  
> > +	trace_instance=[instance-info]
> > +			[FTRACE] Create an ring buffer instance early in boot up.
> > +			This will be listed in:
> > +
> > +				/sys/kernel/tracing/instances  
> 
> Should this be "/sys/kernel/debug/tracing/instances"?
No, the /sys/kernel/debug/tracing is deprecated. It only exists for
backward compatibility. If it's still in documentation, it should be
updated.
> 
> Ditto for the text for 'ftrace_boot_snapshot':
> 
> 	ftrace_boot_snapshot
> 			[FTRACE] On boot up, a snapshot will be taken of the
> 			ftrace ring buffer that can be read at:
> 			/sys/kernel/tracing/snapshot.
> 
> Everywhere else we use /sys/kernel/debug/tracing, though we do use
> /sys/kernel/tracing in Documentation/trace/ftrace.txt ?
Right, that's because it was missed when I was updating it ;-)
All documentation that references /sys/kernel/debug/tracing should be
replaced with /sys/kernel/tracing.
> 
> I guess either works, but having just 1 or the other will help us not confuse
> users.
Agreed. Want to send a clean up patch? ;-)
> 
> > +
> >  	trace_options=[option-list]
> >  			[FTRACE] Enable or disable tracer options at boot.
> >  			The option-list is a comma delimited list of options
> > diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
> > index a555a861b978..34ed504ffca9 100644
> > --- a/kernel/trace/trace.c
> > +++ b/kernel/trace/trace.c
> > @@ -48,6 +48,9 @@
> >  #include <linux/fsnotify.h>
> >  #include <linux/irq_work.h>
> >  #include <linux/workqueue.h>
> > +#include <linux/workqueue.h>  
> 
> Duplicate include 1 line above.
Good catch.
> 
> > +
> > +#include <asm/setup.h> /* COMMAND_LINE_SIZE */
> >  
> >  #include "trace.h"
> >  #include "trace_output.h"
> > @@ -186,6 +189,9 @@ static char *default_bootup_tracer;
> >  static bool allocate_snapshot;
> >  static bool snapshot_at_boot;
> >  
> > +static char boot_instance_info[COMMAND_LINE_SIZE] __initdata;
> > +static int boot_instance_index;
> > +
> >  static int __init set_cmdline_ftrace(char *str)
> >  {
> >  	strlcpy(bootup_tracer_buf, str, MAX_TRACER_SIZE);
> > @@ -239,6 +245,23 @@ static int __init boot_snapshot(char *str)
> >  __setup("ftrace_boot_snapshot", boot_snapshot);
> >  
> >  
> > +static int __init boot_instance(char *str)
> > +{
> > +	char *slot = boot_instance_info + boot_instance_index;
> > +	int left = COMMAND_LINE_SIZE - boot_instance_index;  
> 
> A bit safer to use sizeof(boot_instance_info) instead of COMMAND_LINE_SIZE,
> so we can change the allocation size of boot_instance_info without having to
> keep them in sync.
Either way is fine. I wouldn't make this change if it was the only thing I
needed to fix, but as I need to get rid of the extra "workqueue.h", I can
make this change too.
> 
> These are mostly nits, you can add:
> 
> Reviewed-by: Ross Zwisler <zwisler@...gle.com>
Thanks!
-- Steve
Powered by blists - more mailing lists
 
