The trace output is very verbose with outputing both the
IP address (Instruction Pointer not Internet Protocol!)
and the kallsyms symbol. So if kallsyms is configured into
the kernel, another file is created in the debugfs system.
This is the trace_symonly file that leaves out the IP address.

Here's an example:

CPU 1: swapper:0 smp_apic_timer_interrupt+0xc/0x58 <-- 
apic_timer_interrupt+0x66/0x70
CPU 1: swapper:0 exit_idle+0x9/0x22 <-- smp_apic_timer_interrupt+0x35/0x58
CPU 0: sshd:2611 _spin_unlock+0x9/0x38 <-- __qdisc_run+0xb2/0x1a1
CPU 1: swapper:0 __exit_idle+0x9/0x2e <-- exit_idle+0x20/0x22
CPU 0: sshd:2611 _spin_lock+0xe/0x7a <-- __qdisc_run+0xba/0x1a1
CPU 1: swapper:0 atomic_notifier_call_chain+0x9/0x16 <-- __exit_idle+0x2c/0x2e
CPU 1: swapper:0 __atomic_notifier_call_chain+0xe/0x56 <-- 
atomic_notifier_call_chain+0x14/0x16


Signed-off-by: Steven Rostedt <[EMAIL PROTECTED]>
---
 lib/tracing/tracer.c |   65 +++++++++++++++++++++++++++++++++++++++++++++++----
 lib/tracing/tracer.h |    1 
 2 files changed, 62 insertions(+), 4 deletions(-)

Index: linux-compile-i386.git/lib/tracing/tracer.c
===================================================================
--- linux-compile-i386.git.orig/lib/tracing/tracer.c    2008-01-09 
14:13:46.000000000 -0500
+++ linux-compile-i386.git/lib/tracing/tracer.c 2008-01-09 15:17:37.000000000 
-0500
@@ -79,6 +79,10 @@ static notrace void trace_function(const
 }
 
 #ifdef CONFIG_DEBUG_FS
+enum trace_iterator {
+       TRACE_ITER_SYM_ONLY     = 1,
+};
+
 struct mctracer_iterator {
        struct mctracer_trace *tr;
        struct mctracer_entry *ent;
@@ -207,25 +211,29 @@ static void seq_print_symbol(struct seq_
 #endif
 
 static void notrace seq_print_ip_sym(struct seq_file *m,
-                                    unsigned long ip)
+                                    unsigned long ip,
+                                    int sym_only)
 {
        seq_print_symbol(m, "%s", ip);
-       seq_printf(m, " <" IP_FMT ">", ip);
+       if (!sym_only)
+               seq_printf(m, " <" IP_FMT ">", ip);
 }
 
 static int s_show(struct seq_file *m, void *v)
 {
        struct mctracer_iterator *iter = v;
+       int sym_only = !!(iter->tr->iter_flags & TRACE_ITER_SYM_ONLY);
 
        if (iter->ent == NULL) {
                seq_printf(m, "mctracer:\n");
        } else {
                seq_printf(m, "CPU %d: ", iter->cpu);
                seq_printf(m, "%s:%d ", iter->ent->comm, iter->ent->pid);
-               seq_print_ip_sym(m, iter->ent->ip);
+               seq_print_ip_sym(m, iter->ent->ip, sym_only);
                if (iter->ent->parent_ip) {
                        seq_printf(m, " <-- ");
-                       seq_print_ip_sym(m, iter->ent->parent_ip);
+                       seq_print_ip_sym(m, iter->ent->parent_ip,
+                                        sym_only);
                }
                seq_printf(m, "\n");
        }
@@ -335,6 +343,50 @@ static struct file_operations mctracer_c
        .write = mctracer_ctrl_write,
 };
 
+static ssize_t mctracer_iter_ctrl_read(struct file *filp, char __user *ubuf,
+                                      size_t cnt, loff_t *ppos)
+{
+       struct mctracer_trace *tr = filp->private_data;
+       char buf[64];
+       int r = 0;
+
+       if (tr->iter_flags & TRACE_ITER_SYM_ONLY)
+               r = sprintf(buf, "%s", "symonly ");
+       r += sprintf(buf+r, "\n");
+
+       return simple_read_from_buffer(ubuf, cnt, ppos,
+                                      buf, r);
+}
+
+static ssize_t mctracer_iter_ctrl_write(struct file *filp,
+                                       const char __user *ubuf,
+                                       size_t cnt, loff_t *ppos)
+{
+       struct mctracer_trace *tr = filp->private_data;
+       char buf[64];
+
+       if (cnt > 63)
+               cnt = 63;
+
+       if (copy_from_user(&buf, ubuf, cnt))
+               return -EFAULT;
+
+       buf[cnt] = 0;
+
+       if (strncmp(buf, "symonly", 7) == 0)
+               tr->iter_flags |= TRACE_ITER_SYM_ONLY;
+
+       filp->f_pos += cnt;
+
+       return cnt;
+}
+
+static struct file_operations mctracer_iter_fops = {
+       .open = mctracer_open_generic,
+       .read = mctracer_iter_ctrl_read,
+       .write = mctracer_iter_ctrl_write,
+};
+
 static void mctrace_init_debugfs(void)
 {
        struct dentry *d_mctracer;
@@ -351,10 +403,15 @@ static void mctrace_init_debugfs(void)
        if (!entry)
                pr_warning("Could not create debugfs 'ctrl' entry\n");
 
+       entry = debugfs_create_file("iter_ctrl", 0644, d_mctracer,
+                                   &mctracer_trace, &mctracer_iter_fops);
+       if (!entry)
+               pr_warning("Could not create debugfs 'iter_ctrl' entry\n");
        entry = debugfs_create_file("trace", 0444, d_mctracer,
                                    &mctracer_trace, &mctrace_fops);
        if (!entry)
                pr_warning("Could not create debugfs 'trace' entry\n");
+
 }
 #else /* CONFIG_DEBUG_FS */
 static void mctrace_init_debugfs(void)
Index: linux-compile-i386.git/lib/tracing/tracer.h
===================================================================
--- linux-compile-i386.git.orig/lib/tracing/tracer.h    2008-01-09 
14:13:46.000000000 -0500
+++ linux-compile-i386.git/lib/tracing/tracer.h 2008-01-09 15:17:36.000000000 
-0500
@@ -17,6 +17,7 @@ struct mctracer_trace {
        unsigned long trace_idx[NR_CPUS];
        unsigned long entries;
        long          ctrl;
+       unsigned long iter_flags;
        atomic_t      cnt;
        atomic_t      disabled[NR_CPUS];
        atomic_t      underrun[NR_CPUS];

-- 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to