tracing: show proper address for trace-printk format
authorSteven Rostedt <srostedt@redhat.com>
Thu, 23 Jul 2009 03:11:03 +0000 (23:11 -0400)
committerSteven Rostedt <rostedt@goodmis.org>
Thu, 23 Jul 2009 14:07:17 +0000 (10:07 -0400)
Since the trace_printk may use pointers to the format fields
in the buffer, they are exported via debugfs/tracing/printk_formats.
This is used by utilities that read the ring buffer in binary format.
It helps the utilities map the address of the format in the binary
buffer to what the printf format looks like.

Unfortunately, the way the output code works, it exports the address
of the pointer to the format address, and not the format address
itself. This makes the file totally useless in trying to figure
out what format string a binary address belongs to.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/trace_printk.c

index 7b627811082736e6cdb973b21f6f6ca5b623954f..687699d365aeb328eddaf619f04ccf10b1cc6b6c 100644 (file)
@@ -176,7 +176,7 @@ static int t_show(struct seq_file *m, void *v)
        const char *str = *fmt;
        int i;
 
-       seq_printf(m, "0x%lx : \"", (unsigned long)fmt);
+       seq_printf(m, "0x%lx : \"", *(unsigned long *)fmt);
 
        /*
         * Tabs and new lines need to be converted.