From: Tom Zanussi <tzanussi@gmail.com>
To: linux-tip-commits@vger.kernel.org
Cc: linux-kernel@vger.kernel.org, hpa@zytor.com, mingo@redhat.com,
fweisbec@gmail.com, tzanussi@gmail.com, rostedt@goodmis.org,
tglx@linutronix.de, mingo@elte.hu
Subject: [tip:tracing/filters] tracing/filters: use trace_seq_printf() to print filters
Date: Tue, 24 Mar 2009 07:27:55 GMT [thread overview]
Message-ID: <tip-4bda2d517bfa3ce3d7044e06988cdddae7adffe2@git.kernel.org> (raw)
In-Reply-To: <1237878871.8339.59.camel@charm-linux>
Commit-ID: 4bda2d517bfa3ce3d7044e06988cdddae7adffe2
Gitweb: http://git.kernel.org/tip/4bda2d517bfa3ce3d7044e06988cdddae7adffe2
Author: Tom Zanussi <tzanussi@gmail.com>
AuthorDate: Tue, 24 Mar 2009 02:14:31 -0500
Committer: Ingo Molnar <mingo@elte.hu>
CommitDate: Tue, 24 Mar 2009 08:26:52 +0100
tracing/filters: use trace_seq_printf() to print filters
Impact: cleanup
Instead of just using the trace_seq buffer to print the filters, use
trace_seq_printf() as it was intended to be used.
Reported-by: Steven Rostedt <rostedt@goodmis.org>
Signed-off-by: Tom Zanussi <tzanussi@gmail.com>
Cc: =?ISO-8859-1?Q?Fr=E9d=E9ric?= Weisbecker <fweisbec@gmail.com>
LKML-Reference: <1237878871.8339.59.camel@charm-linux>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
---
kernel/trace/trace.h | 3 ++-
kernel/trace/trace_events.c | 8 ++++----
kernel/trace/trace_events_filter.c | 25 +++++++++----------------
3 files changed, 15 insertions(+), 21 deletions(-)
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index 54fd9bc..90a848d 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -840,7 +840,8 @@ struct filter_pred {
int trace_define_field(struct ftrace_event_call *call, char *type,
char *name, int offset, int size);
extern void filter_free_pred(struct filter_pred *pred);
-extern int filter_print_preds(struct filter_pred **preds, char *buf);
+extern void filter_print_preds(struct filter_pred **preds,
+ struct trace_seq *s);
extern int filter_parse(char **pbuf, struct filter_pred *pred);
extern int filter_add_pred(struct ftrace_event_call *call,
struct filter_pred *pred);
diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
index a938138..d132997 100644
--- a/kernel/trace/trace_events.c
+++ b/kernel/trace/trace_events.c
@@ -481,8 +481,8 @@ event_filter_read(struct file *filp, char __user *ubuf, size_t cnt,
trace_seq_init(s);
- r = filter_print_preds(call->preds, s->buffer);
- r = simple_read_from_buffer(ubuf, cnt, ppos, s->buffer, r);
+ filter_print_preds(call->preds, s);
+ r = simple_read_from_buffer(ubuf, cnt, ppos, s->buffer, s->len);
kfree(s);
@@ -547,8 +547,8 @@ subsystem_filter_read(struct file *filp, char __user *ubuf, size_t cnt,
trace_seq_init(s);
- r = filter_print_preds(system->preds, s->buffer);
- r = simple_read_from_buffer(ubuf, cnt, ppos, s->buffer, r);
+ filter_print_preds(system->preds, s);
+ r = simple_read_from_buffer(ubuf, cnt, ppos, s->buffer, s->len);
kfree(s);
diff --git a/kernel/trace/trace_events_filter.c b/kernel/trace/trace_events_filter.c
index 3f0b79f..9fca8bb 100644
--- a/kernel/trace/trace_events_filter.c
+++ b/kernel/trace/trace_events_filter.c
@@ -24,6 +24,7 @@
#include <linux/ctype.h>
#include "trace.h"
+#include "trace_output.h"
static int filter_pred_64(struct filter_pred *pred, void *event)
{
@@ -108,16 +109,15 @@ int filter_match_preds(struct ftrace_event_call *call, void *rec)
return 1;
}
-int filter_print_preds(struct filter_pred **preds, char *buf)
+void filter_print_preds(struct filter_pred **preds, struct trace_seq *s)
{
- ssize_t this_len = 0;
char *field_name;
struct filter_pred *pred;
int i;
if (!preds) {
- this_len += sprintf(buf + this_len, "none\n");
- return this_len;
+ trace_seq_printf(s, "none\n");
+ return;
}
for (i = 0; i < MAX_FILTER_PRED; i++) {
@@ -125,23 +125,16 @@ int filter_print_preds(struct filter_pred **preds, char *buf)
pred = preds[i];
field_name = pred->field_name;
if (i)
- this_len += sprintf(buf + this_len,
- pred->or ? "|| " : "&& ");
- this_len += sprintf(buf + this_len,
- "%s ", field_name);
- this_len += sprintf(buf + this_len,
- pred->not ? "!= " : "== ");
+ trace_seq_printf(s, pred->or ? "|| " : "&& ");
+ trace_seq_printf(s, "%s ", field_name);
+ trace_seq_printf(s, pred->not ? "!= " : "== ");
if (pred->str_val)
- this_len += sprintf(buf + this_len,
- "%s\n", pred->str_val);
+ trace_seq_printf(s, "%s\n", pred->str_val);
else
- this_len += sprintf(buf + this_len,
- "%llu\n", pred->val);
+ trace_seq_printf(s, "%llu\n", pred->val);
} else
break;
}
-
- return this_len;
}
static struct ftrace_event_field *
prev parent reply other threads:[~2009-03-24 7:28 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-03-24 7:14 [PATCH] tracing/filters: use trace_seq_printf() to print filters Tom Zanussi
2009-03-24 7:27 ` Tom Zanussi [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=tip-4bda2d517bfa3ce3d7044e06988cdddae7adffe2@git.kernel.org \
--to=tzanussi@gmail.com \
--cc=fweisbec@gmail.com \
--cc=hpa@zytor.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-tip-commits@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=mingo@redhat.com \
--cc=rostedt@goodmis.org \
--cc=tglx@linutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox