* trace: fix multiple use of __print_flags and __print_symbolic @ 2009-06-03 9:05 Steven Whitehouse 2009-06-03 9:50 ` Li Zefan 0 siblings, 1 reply; 7+ messages in thread From: Steven Whitehouse @ 2009-06-03 9:05 UTC (permalink / raw) To: Steven Rostedt Cc: linux-kernel, cluster-devel, Christoph Hellwig, Ingo Molnar When using multiple calls to __print_symbolic and __print_flags in the same tracer, I noticed that the output was incorrect. I think the following patch is the correct fix (it works for me) but please check it carefully since I'm not that familiar with this code, and I may well have made a mistake somewhere. The patch is vs. the latest -tip tree which doesn't yet seem to contain the EXPORT_SYMBOL() fix that I sent earlier. Signed-off-by: Steven Whitehouse <swhiteho@redhat.com> diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c index c12d95d..ac6ced1 100644 --- a/kernel/trace/trace_output.c +++ b/kernel/trace/trace_output.c @@ -222,10 +222,9 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, { unsigned long mask; const char *str; + const char *ret = p->buffer + p->len; int i; - trace_seq_init(p); - for (i = 0; flag_array[i].name && flags; i++) { mask = flag_array[i].mask; @@ -248,7 +247,7 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, trace_seq_putc(p, 0); - return p->buffer; + return ret; } const char * @@ -256,8 +255,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, const struct trace_print_flags *symbol_array) { int i; - - trace_seq_init(p); + const char *ret = p->buffer + p->len; for (i = 0; symbol_array[i].name; i++) { @@ -273,7 +271,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, trace_seq_putc(p, 0); - return p->buffer; + return ret; } #ifdef CONFIG_KRETPROBES ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: trace: fix multiple use of __print_flags and __print_symbolic 2009-06-03 9:05 trace: fix multiple use of __print_flags and __print_symbolic Steven Whitehouse @ 2009-06-03 9:50 ` Li Zefan 2009-06-03 9:54 ` Steven Whitehouse 2009-06-03 12:57 ` Steven Whitehouse 0 siblings, 2 replies; 7+ messages in thread From: Li Zefan @ 2009-06-03 9:50 UTC (permalink / raw) To: Steven Whitehouse Cc: Steven Rostedt, linux-kernel, cluster-devel, Christoph Hellwig, Ingo Molnar Steven Whitehouse wrote: > When using multiple calls to __print_symbolic and __print_flags in > the same tracer, I noticed that the output was incorrect. I think > the following patch is the correct fix (it works for me) but please > check it carefully since I'm not that familiar with this code, > and I may well have made a mistake somewhere. > I don't see there's bug in __print_symbolic() or __print_flags(): enum print_line_t ftrace_raw_output_##call(struct trace_iterator *iter, int flags) { ... p = &get_cpu_var(ftrace_event_seq); /* here we call ftrace_print_flags_seq(p, ...) */ ret = trace_seq_printf(s, #call ": " print); put_cpu(); ... } ftrace_event_seq is percpu data, and here is used with preempt-disabled, so there shouldn't be problem of concurrent accessing. > The patch is vs. the latest -tip tree which doesn't yet seem to > contain the EXPORT_SYMBOL() fix that I sent earlier. > > Signed-off-by: Steven Whitehouse <swhiteho@redhat.com> > > > diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c > index c12d95d..ac6ced1 100644 > --- a/kernel/trace/trace_output.c > +++ b/kernel/trace/trace_output.c > @@ -222,10 +222,9 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, > { > unsigned long mask; > const char *str; > + const char *ret = p->buffer + p->len; > int i; > > - trace_seq_init(p); > - This is wrong. Without reseting, the seq buffer will quickly be filled. > for (i = 0; flag_array[i].name && flags; i++) { > > mask = flag_array[i].mask; > @@ -248,7 +247,7 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, > > trace_seq_putc(p, 0); > > - return p->buffer; > + return ret; > } > > const char * > @@ -256,8 +255,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, > const struct trace_print_flags *symbol_array) > { > int i; > - > - trace_seq_init(p); > + const char *ret = p->buffer + p->len; > > for (i = 0; symbol_array[i].name; i++) { > > @@ -273,7 +271,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, > > trace_seq_putc(p, 0); > > - return p->buffer; > + return ret; > } > > #ifdef CONFIG_KRETPROBES > ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: trace: fix multiple use of __print_flags and __print_symbolic 2009-06-03 9:50 ` Li Zefan @ 2009-06-03 9:54 ` Steven Whitehouse 2009-06-03 12:57 ` Steven Whitehouse 1 sibling, 0 replies; 7+ messages in thread From: Steven Whitehouse @ 2009-06-03 9:54 UTC (permalink / raw) To: Li Zefan Cc: Steven Rostedt, linux-kernel, cluster-devel, Christoph Hellwig, Ingo Molnar Hi, On Wed, 2009-06-03 at 17:50 +0800, Li Zefan wrote: > Steven Whitehouse wrote: > > When using multiple calls to __print_symbolic and __print_flags in > > the same tracer, I noticed that the output was incorrect. I think > > the following patch is the correct fix (it works for me) but please > > check it carefully since I'm not that familiar with this code, > > and I may well have made a mistake somewhere. > > > > I don't see there's bug in __print_symbolic() or __print_flags(): > > enum print_line_t > ftrace_raw_output_##call(struct trace_iterator *iter, int flags) > { > ... > p = &get_cpu_var(ftrace_event_seq); > /* here we call ftrace_print_flags_seq(p, ...) */ > ret = trace_seq_printf(s, #call ": " print); > put_cpu(); > ... > } > > ftrace_event_seq is percpu data, and here is used with preempt-disabled, > so there shouldn't be problem of concurrent accessing. > > Well without the "fix" every call to __print_symbolic and __print_flags seems to result in printing the same string, so with: TP_printk("%u.%u glock %d:%lld state %s => %s tgt:%s dmt:%s flags:%s", MAJOR(__entry->dev), MINOR(__entry->dev), __entry->gltype, (unsigned long long)__entry->glnum, glock_trace_name(__entry->cur_state), glock_trace_name(__entry->new_state), glock_trace_name(__entry->tgt_state), glock_trace_name(__entry->dmt_state), show_glock_flags(__entry->flags)) and #define dlm_state_name(nn) { DLM_LOCK_##nn, #nn } #define glock_trace_name(x) __print_symbolic(x, \ dlm_state_name(IV), \ dlm_state_name(NL), \ dlm_state_name(CR), \ dlm_state_name(CW), \ dlm_state_name(PR), \ dlm_state_name(PW), \ dlm_state_name(EX)) #define show_glock_flags(flags) __print_flags(flags, "", \ {(1UL << GLF_LOCK), "l" }, \ {(1UL << GLF_DEMOTE), "D" }, \ {(1UL << GLF_PENDING_DEMOTE), "d" }, \ {(1UL << GLF_DEMOTE_IN_PROGRESS), "p" }, \ {(1UL << GLF_DIRTY), "y" }, \ {(1UL << GLF_LFLUSH), "f" }, \ {(1UL << GLF_INVALIDATE_IN_PROGRESS), "i" }, \ {(1UL << GLF_REPLY_PENDING), "r" }, \ {(1UL << GLF_INITIAL), "I" }, \ {(1UL << GLF_FROZEN), "F" }) every call to glock_trace_name and the call to glock_show_flags resulted in the string "EX" when I was testing it. With the previous version of my patch where I did the constant to string conversion with my own function, this didn't happen. Applying the patch corrects the output, so there is a bug here I think, even if I've not found the correct fix for it, Steve. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: trace: fix multiple use of __print_flags and __print_symbolic 2009-06-03 9:50 ` Li Zefan 2009-06-03 9:54 ` Steven Whitehouse @ 2009-06-03 12:57 ` Steven Whitehouse 2009-06-03 13:23 ` Steven Rostedt 1 sibling, 1 reply; 7+ messages in thread From: Steven Whitehouse @ 2009-06-03 12:57 UTC (permalink / raw) To: Li Zefan Cc: Steven Rostedt, linux-kernel, cluster-devel, Christoph Hellwig, Ingo Molnar Hi On Wed, 2009-06-03 at 17:50 +0800, Li Zefan wrote: > Steven Whitehouse wrote: > > When using multiple calls to __print_symbolic and __print_flags in > > the same tracer, I noticed that the output was incorrect. I think > > the following patch is the correct fix (it works for me) but please > > check it carefully since I'm not that familiar with this code, > > and I may well have made a mistake somewhere. > > > > I don't see there's bug in __print_symbolic() or __print_flags(): > > enum print_line_t > ftrace_raw_output_##call(struct trace_iterator *iter, int flags) > { > ... > p = &get_cpu_var(ftrace_event_seq); > /* here we call ftrace_print_flags_seq(p, ...) */ > ret = trace_seq_printf(s, #call ": " print); > put_cpu(); > ... > } > > ftrace_event_seq is percpu data, and here is used with preempt-disabled, > so there shouldn't be problem of concurrent accessing. > I've double checked this now, and I'm seeing results like: glock_workqueue-2482 [001] 809.956985: gfs2_glock_state_change: 8.7 glock 2:33119 state EX => EX tgt:EX dmt:EX flags:EX glock_workqueue-2482 [001] 809.957155: gfs2_glock_state_change: 8.7 glock 2:33119 state NL => NL tgt:NL dmt:NL flags:NL glock_workqueue-2482 [001] 809.959473: gfs2_glock_state_change: 8.7 glock 1:2 state NL => NL tgt:NL dmt:NL flags:NL glock_workqueue-2482 [001] 809.959556: gfs2_glock_state_change: 8.7 glock 2:33119 state EX => EX tgt:EX dmt:EX flags:EX glock_workqueue-2482 [001] 810.008773: gfs2_glock_state_change: 8.7 glock 1:0 state EX => EX tgt:EX dmt:EX flags:EX without the patch, which is clearly wrong, Steve. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: trace: fix multiple use of __print_flags and __print_symbolic 2009-06-03 12:57 ` Steven Whitehouse @ 2009-06-03 13:23 ` Steven Rostedt 2009-06-03 13:52 ` Steven Whitehouse 0 siblings, 1 reply; 7+ messages in thread From: Steven Rostedt @ 2009-06-03 13:23 UTC (permalink / raw) To: Steven Whitehouse Cc: Li Zefan, linux-kernel, cluster-devel, Christoph Hellwig, Ingo Molnar On Wed, 3 Jun 2009, Steven Whitehouse wrote: > Hi > > On Wed, 2009-06-03 at 17:50 +0800, Li Zefan wrote: > > Steven Whitehouse wrote: > > > When using multiple calls to __print_symbolic and __print_flags in > > > the same tracer, I noticed that the output was incorrect. I think > > > the following patch is the correct fix (it works for me) but please > > > check it carefully since I'm not that familiar with this code, > > > and I may well have made a mistake somewhere. > > > > > > > I don't see there's bug in __print_symbolic() or __print_flags(): > > > > enum print_line_t > > ftrace_raw_output_##call(struct trace_iterator *iter, int flags) > > { > > ... > > p = &get_cpu_var(ftrace_event_seq); > > /* here we call ftrace_print_flags_seq(p, ...) */ > > ret = trace_seq_printf(s, #call ": " print); > > put_cpu(); > > ... > > } > > > > ftrace_event_seq is percpu data, and here is used with preempt-disabled, > > so there shouldn't be problem of concurrent accessing. > > > I've double checked this now, and I'm seeing results like: > > > glock_workqueue-2482 [001] 809.956985: gfs2_glock_state_change: 8.7 glock 2:33119 state EX => EX tgt:EX dmt:EX flags:EX > glock_workqueue-2482 [001] 809.957155: gfs2_glock_state_change: 8.7 glock 2:33119 state NL => NL tgt:NL dmt:NL flags:NL > glock_workqueue-2482 [001] 809.959473: gfs2_glock_state_change: 8.7 glock 1:2 state NL => NL tgt:NL dmt:NL flags:NL > glock_workqueue-2482 [001] 809.959556: gfs2_glock_state_change: 8.7 glock 2:33119 state EX => EX tgt:EX dmt:EX flags:EX > glock_workqueue-2482 [001] 810.008773: gfs2_glock_state_change: 8.7 glock 1:0 state EX => EX tgt:EX dmt:EX flags:EX > > > without the patch, which is clearly wrong, Ah, I did not account for having multiple instances of print_symbol of print_flags in a single print. Your patch is partialy correct. Add a: trace_seq_init(p); after the "p = &get_cpu_var(ftrace_event_seq);". -- Steve ^ permalink raw reply [flat|nested] 7+ messages in thread
* trace: fix multiple use of __print_flags and __print_symbolic 2009-06-03 13:23 ` Steven Rostedt @ 2009-06-03 13:52 ` Steven Whitehouse 2009-06-07 10:22 ` [tip:tracing/core] tracing: " tip-bot for Steven Whitehouse 0 siblings, 1 reply; 7+ messages in thread From: Steven Whitehouse @ 2009-06-03 13:52 UTC (permalink / raw) To: Steven Rostedt Cc: Li Zefan, linux-kernel, cluster-devel, Christoph Hellwig, Ingo Molnar Here is an updated patch to include the extra call to trace_seq_init() as requested. This is vs. the latest -tip tree and fixes the use of multiple __print_flags and __print_symbolic in a single tracer. Also tested to ensure its working now: mount.gfs2-2534 [000] 235.850587: gfs2_glock_queue: 8.7 glock 1:2 dequeue PR mount.gfs2-2534 [000] 235.850591: gfs2_demote_rq: 8.7 glock 1:0 demote EX to NL flags:DI mount.gfs2-2534 [000] 235.850591: gfs2_glock_queue: 8.7 glock 1:0 dequeue EX glock_workqueue-2529 [000] 235.850666: gfs2_glock_state_change: 8.7 glock 1:0 state EX => NL tgt:NL dmt:NL flags:lDpI glock_workqueue-2529 [000] 235.850672: gfs2_glock_put: 8.7 glock 1:0 state NL => IV flags:I Signed-off-by: Steven Whitehouse <swhiteho@redhat.com> diff --git a/include/trace/ftrace.h b/include/trace/ftrace.h index b4ec83a..1c58f05 100644 --- a/include/trace/ftrace.h +++ b/include/trace/ftrace.h @@ -100,6 +100,7 @@ * field = (typeof(field))entry; * * p = get_cpu_var(ftrace_event_seq); + * trace_seq_init(p); * ret = trace_seq_printf(s, <TP_printk> "\n"); * put_cpu(); * if (!ret) @@ -159,6 +160,7 @@ ftrace_raw_output_##call(struct trace_iterator *iter, int flags) \ field = (typeof(field))entry; \ \ p = &get_cpu_var(ftrace_event_seq); \ + trace_seq_init(p); \ ret = trace_seq_printf(s, #call ": " print); \ put_cpu(); \ if (!ret) \ diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c index c12d95d..ac6ced1 100644 --- a/kernel/trace/trace_output.c +++ b/kernel/trace/trace_output.c @@ -222,10 +222,9 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, { unsigned long mask; const char *str; + const char *ret = p->buffer + p->len; int i; - trace_seq_init(p); - for (i = 0; flag_array[i].name && flags; i++) { mask = flag_array[i].mask; @@ -248,7 +247,7 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, trace_seq_putc(p, 0); - return p->buffer; + return ret; } const char * @@ -256,8 +255,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, const struct trace_print_flags *symbol_array) { int i; - - trace_seq_init(p); + const char *ret = p->buffer + p->len; for (i = 0; symbol_array[i].name; i++) { @@ -273,7 +271,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, trace_seq_putc(p, 0); - return p->buffer; + return ret; } #ifdef CONFIG_KRETPROBES ^ permalink raw reply related [flat|nested] 7+ messages in thread
* [tip:tracing/core] tracing: fix multiple use of __print_flags and __print_symbolic 2009-06-03 13:52 ` Steven Whitehouse @ 2009-06-07 10:22 ` tip-bot for Steven Whitehouse 0 siblings, 0 replies; 7+ messages in thread From: tip-bot for Steven Whitehouse @ 2009-06-07 10:22 UTC (permalink / raw) To: linux-tip-commits; +Cc: linux-kernel, swhiteho, hpa, mingo, rostedt, tglx Commit-ID: 56d8bd3f0b98972312cad683947ec90b21011199 Gitweb: http://git.kernel.org/tip/56d8bd3f0b98972312cad683947ec90b21011199 Author: Steven Whitehouse <swhiteho@redhat.com> AuthorDate: Wed, 3 Jun 2009 14:52:03 +0100 Committer: Steven Rostedt <rostedt@goodmis.org> CommitDate: Wed, 3 Jun 2009 10:29:48 -0400 tracing: fix multiple use of __print_flags and __print_symbolic Here is an updated patch to include the extra call to trace_seq_init() as requested. This is vs. the latest -tip tree and fixes the use of multiple __print_flags and __print_symbolic in a single tracer. Also tested to ensure its working now: mount.gfs2-2534 [000] 235.850587: gfs2_glock_queue: 8.7 glock 1:2 dequeue PR mount.gfs2-2534 [000] 235.850591: gfs2_demote_rq: 8.7 glock 1:0 demote EX to NL flags:DI mount.gfs2-2534 [000] 235.850591: gfs2_glock_queue: 8.7 glock 1:0 dequeue EX glock_workqueue-2529 [000] 235.850666: gfs2_glock_state_change: 8.7 glock 1:0 state EX => NL tgt:NL dmt:NL flags:lDpI glock_workqueue-2529 [000] 235.850672: gfs2_glock_put: 8.7 glock 1:0 state NL => IV flags:I Signed-off-by: Steven Whitehouse <swhiteho@redhat.com> LKML-Reference: <1244037123.29604.603.camel@localhost.localdomain> Signed-off-by: Steven Rostedt <rostedt@goodmis.org> --- include/trace/ftrace.h | 2 ++ kernel/trace/trace_output.c | 10 ++++------ 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/include/trace/ftrace.h b/include/trace/ftrace.h index b5478da..40ede4d 100644 --- a/include/trace/ftrace.h +++ b/include/trace/ftrace.h @@ -104,6 +104,7 @@ * field = (typeof(field))entry; * * p = get_cpu_var(ftrace_event_seq); + * trace_seq_init(p); * ret = trace_seq_printf(s, <TP_printk> "\n"); * put_cpu(); * if (!ret) @@ -167,6 +168,7 @@ ftrace_raw_output_##call(struct trace_iterator *iter, int flags) \ field = (typeof(field))entry; \ \ p = &get_cpu_var(ftrace_event_seq); \ + trace_seq_init(p); \ ret = trace_seq_printf(s, #call ": " print); \ put_cpu(); \ if (!ret) \ diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c index 8dadbbb..8afeea4 100644 --- a/kernel/trace/trace_output.c +++ b/kernel/trace/trace_output.c @@ -223,10 +223,9 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, { unsigned long mask; const char *str; + const char *ret = p->buffer + p->len; int i; - trace_seq_init(p); - for (i = 0; flag_array[i].name && flags; i++) { mask = flag_array[i].mask; @@ -249,7 +248,7 @@ ftrace_print_flags_seq(struct trace_seq *p, const char *delim, trace_seq_putc(p, 0); - return p->buffer; + return ret; } EXPORT_SYMBOL(ftrace_print_flags_seq); @@ -258,8 +257,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, const struct trace_print_flags *symbol_array) { int i; - - trace_seq_init(p); + const char *ret = p->buffer + p->len; for (i = 0; symbol_array[i].name; i++) { @@ -275,7 +273,7 @@ ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, trace_seq_putc(p, 0); - return p->buffer; + return ret; } EXPORT_SYMBOL(ftrace_print_symbols_seq); ^ permalink raw reply related [flat|nested] 7+ messages in thread
end of thread, other threads:[~2009-06-07 10:22 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2009-06-03 9:05 trace: fix multiple use of __print_flags and __print_symbolic Steven Whitehouse 2009-06-03 9:50 ` Li Zefan 2009-06-03 9:54 ` Steven Whitehouse 2009-06-03 12:57 ` Steven Whitehouse 2009-06-03 13:23 ` Steven Rostedt 2009-06-03 13:52 ` Steven Whitehouse 2009-06-07 10:22 ` [tip:tracing/core] tracing: " tip-bot for Steven Whitehouse
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox