* 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