aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrederic Weisbecker <fweisbec@gmail.com>2008-09-29 14:27:42 -0400
committerIngo Molnar <mingo@elte.hu>2008-10-14 04:39:02 -0400
commit07f4e4f790895d55f46aaf89e7437da4a585989c (patch)
treec2b6cecb4f27e572c3a325f1c1d868cbcc0e6099
parent9ff4b9744c187cae58c3774361ea090addbc4130 (diff)
tracing/ftrace: adapt mmiotrace to the new type of print_line
Adapt mmiotrace to the new print_line type. By default, it ignores (and consumes) types it doesn't support. Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Acked-by: Pekka Paalanen <pq@iki.fi> Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r--kernel/trace/trace_mmiotrace.c25
1 files changed, 12 insertions, 13 deletions
diff --git a/kernel/trace/trace_mmiotrace.c b/kernel/trace/trace_mmiotrace.c
index 3df441ea2749..1a266aa08e1a 100644
--- a/kernel/trace/trace_mmiotrace.c
+++ b/kernel/trace/trace_mmiotrace.c
@@ -175,7 +175,7 @@ print_out:
175 return (ret == -EBUSY) ? 0 : ret; 175 return (ret == -EBUSY) ? 0 : ret;
176} 176}
177 177
178static int mmio_print_rw(struct trace_iterator *iter) 178static enum print_line_t mmio_print_rw(struct trace_iterator *iter)
179{ 179{
180 struct trace_entry *entry = iter->ent; 180 struct trace_entry *entry = iter->ent;
181 struct trace_mmiotrace_rw *field = 181 struct trace_mmiotrace_rw *field =
@@ -215,11 +215,11 @@ static int mmio_print_rw(struct trace_iterator *iter)
215 break; 215 break;
216 } 216 }
217 if (ret) 217 if (ret)
218 return 1; 218 return TRACE_TYPE_HANDLED;
219 return 0; 219 return TRACE_TYPE_PARTIAL_LINE;
220} 220}
221 221
222static int mmio_print_map(struct trace_iterator *iter) 222static enum print_line_t mmio_print_map(struct trace_iterator *iter)
223{ 223{
224 struct trace_entry *entry = iter->ent; 224 struct trace_entry *entry = iter->ent;
225 struct mmiotrace_map *m = (struct mmiotrace_map *)entry; 225 struct mmiotrace_map *m = (struct mmiotrace_map *)entry;
@@ -227,7 +227,7 @@ static int mmio_print_map(struct trace_iterator *iter)
227 unsigned long long t = ns2usecs(iter->ts); 227 unsigned long long t = ns2usecs(iter->ts);
228 unsigned long usec_rem = do_div(t, 1000000ULL); 228 unsigned long usec_rem = do_div(t, 1000000ULL);
229 unsigned secs = (unsigned long)t; 229 unsigned secs = (unsigned long)t;
230 int ret = 1; 230 int ret;
231 231
232 switch (m->opcode) { 232 switch (m->opcode) {
233 case MMIO_PROBE: 233 case MMIO_PROBE:
@@ -247,11 +247,11 @@ static int mmio_print_map(struct trace_iterator *iter)
247 break; 247 break;
248 } 248 }
249 if (ret) 249 if (ret)
250 return 1; 250 return TRACE_TYPE_HANDLED;
251 return 0; 251 return TRACE_TYPE_PARTIAL_LINE;
252} 252}
253 253
254static int mmio_print_mark(struct trace_iterator *iter) 254static enum print_line_t mmio_print_mark(struct trace_iterator *iter)
255{ 255{
256 struct trace_entry *entry = iter->ent; 256 struct trace_entry *entry = iter->ent;
257 struct print_entry *print = (struct print_entry *)entry; 257 struct print_entry *print = (struct print_entry *)entry;
@@ -265,16 +265,15 @@ static int mmio_print_mark(struct trace_iterator *iter)
265 /* The trailing newline must be in the message. */ 265 /* The trailing newline must be in the message. */
266 ret = trace_seq_printf(s, "MARK %lu.%06lu %s", secs, usec_rem, msg); 266 ret = trace_seq_printf(s, "MARK %lu.%06lu %s", secs, usec_rem, msg);
267 if (!ret) 267 if (!ret)
268 return 0; 268 return TRACE_TYPE_PARTIAL_LINE;
269 269
270 if (entry->flags & TRACE_FLAG_CONT) 270 if (entry->flags & TRACE_FLAG_CONT)
271 trace_seq_print_cont(s, iter); 271 trace_seq_print_cont(s, iter);
272 272
273 return 1; 273 return TRACE_TYPE_HANDLED;
274} 274}
275 275
276/* return 0 to abort printing without consuming current entry in pipe mode */ 276static enum print_line_t mmio_print_line(struct trace_iterator *iter)
277static int mmio_print_line(struct trace_iterator *iter)
278{ 277{
279 switch (iter->ent->type) { 278 switch (iter->ent->type) {
280 case TRACE_MMIO_RW: 279 case TRACE_MMIO_RW:
@@ -284,7 +283,7 @@ static int mmio_print_line(struct trace_iterator *iter)
284 case TRACE_PRINT: 283 case TRACE_PRINT:
285 return mmio_print_mark(iter); 284 return mmio_print_mark(iter);
286 default: 285 default:
287 return 1; /* ignore unknown entries */ 286 return TRACE_TYPE_HANDLED; /* ignore unknown entries */
288 } 287 }
289} 288}
290 289