aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLi Zefan <lizf@cn.fujitsu.com>2009-12-07 22:16:11 -0500
committerFrederic Weisbecker <fweisbec@gmail.com>2009-12-13 12:37:27 -0500
commit13f16d209161c95e92aef40e350cc6cf56ac440b (patch)
treea8e3bc78c7b07f5dab8776d91642d29ea1783fb8
parentfdb372ed4cadbfe9dbba0e932a77d0523682e690 (diff)
tracing: Use seq file for trace_clock
The buffer for the output is as small as 64 bytes, so it'll overflow if we add more clock type. Use seq file instead. Signed-off-by: Li Zefan <lizf@cn.fujitsu.com> Acked-by: Steven Rostedt <rostedt@goodmis.org> LKML-Reference: <4B1DC4FB.5030407@cn.fujitsu.com> Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
-rw-r--r--kernel/trace/trace.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index a6c41cc63285..886268e0d8ee 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -3366,21 +3366,18 @@ tracing_mark_write(struct file *filp, const char __user *ubuf,
3366 return cnt; 3366 return cnt;
3367} 3367}
3368 3368
3369static ssize_t tracing_clock_read(struct file *filp, char __user *ubuf, 3369static int tracing_clock_show(struct seq_file *m, void *v)
3370 size_t cnt, loff_t *ppos)
3371{ 3370{
3372 char buf[64];
3373 int bufiter = 0;
3374 int i; 3371 int i;
3375 3372
3376 for (i = 0; i < ARRAY_SIZE(trace_clocks); i++) 3373 for (i = 0; i < ARRAY_SIZE(trace_clocks); i++)
3377 bufiter += snprintf(buf + bufiter, sizeof(buf) - bufiter, 3374 seq_printf(m,
3378 "%s%s%s%s", i ? " " : "", 3375 "%s%s%s%s", i ? " " : "",
3379 i == trace_clock_id ? "[" : "", trace_clocks[i].name, 3376 i == trace_clock_id ? "[" : "", trace_clocks[i].name,
3380 i == trace_clock_id ? "]" : ""); 3377 i == trace_clock_id ? "]" : "");
3381 bufiter += snprintf(buf + bufiter, sizeof(buf) - bufiter, "\n"); 3378 seq_putc(m, '\n');
3382 3379
3383 return simple_read_from_buffer(ubuf, cnt, ppos, buf, bufiter); 3380 return 0;
3384} 3381}
3385 3382
3386static ssize_t tracing_clock_write(struct file *filp, const char __user *ubuf, 3383static ssize_t tracing_clock_write(struct file *filp, const char __user *ubuf,
@@ -3422,6 +3419,13 @@ static ssize_t tracing_clock_write(struct file *filp, const char __user *ubuf,
3422 return cnt; 3419 return cnt;
3423} 3420}
3424 3421
3422static int tracing_clock_open(struct inode *inode, struct file *file)
3423{
3424 if (tracing_disabled)
3425 return -ENODEV;
3426 return single_open(file, tracing_clock_show, NULL);
3427}
3428
3425static const struct file_operations tracing_max_lat_fops = { 3429static const struct file_operations tracing_max_lat_fops = {
3426 .open = tracing_open_generic, 3430 .open = tracing_open_generic,
3427 .read = tracing_max_lat_read, 3431 .read = tracing_max_lat_read,
@@ -3460,8 +3464,10 @@ static const struct file_operations tracing_mark_fops = {
3460}; 3464};
3461 3465
3462static const struct file_operations trace_clock_fops = { 3466static const struct file_operations trace_clock_fops = {
3463 .open = tracing_open_generic, 3467 .open = tracing_clock_open,
3464 .read = tracing_clock_read, 3468 .read = seq_read,
3469 .llseek = seq_lseek,
3470 .release = single_release,
3465 .write = tracing_clock_write, 3471 .write = tracing_clock_write,
3466}; 3472};
3467 3473