[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20100825013238.GE28360@kryten>
Date: Wed, 25 Aug 2010 11:32:38 +1000
From: Anton Blanchard <anton@...ba.org>
To: rostedt@...dmis.org, fweisbec@...il.com, mingo@...hat.com
Cc: linux-kernel@...r.kernel.org
Subject: [PATCH] tracing/trace_stack: Fix stack trace on ppc64
save_stack_trace() stores the instruction pointer, not the function
descriptor. On ppc64 the trace stack code currently dereferences the
instruction pointer and shows 8 bytes of instructions in our backtraces:
# cat /sys/kernel/debug/tracing/stack_trace
Depth Size Location (26 entries)
----- ---- --------
0) 5424 112 0x6000000048000004
1) 5312 160 0x60000000ebad01b0
2) 5152 160 0x2c23000041c20030
3) 4992 240 0x600000007c781b79
4) 4752 160 0xe84100284800000c
5) 4592 192 0x600000002fa30000
6) 4400 256 0x7f1800347b7407e0
7) 4144 208 0xe89f0108f87f0070
8) 3936 272 0xe84100282fa30000
Since we aren't dealing with function descriptors, use %pS instead of %pF
to fix it:
# cat /sys/kernel/debug/tracing/stack_trace
Depth Size Location (26 entries)
----- ---- --------
0) 5424 112 ftrace_call+0x4/0x8
1) 5312 160 .current_io_context+0x28/0x74
2) 5152 160 .get_io_context+0x48/0xa0
3) 4992 240 .cfq_set_request+0x94/0x4c4
4) 4752 160 .elv_set_request+0x60/0x84
5) 4592 192 .get_request+0x2d4/0x468
6) 4400 256 .get_request_wait+0x7c/0x258
7) 4144 208 .__make_request+0x49c/0x610
8) 3936 272 .generic_make_request+0x390/0x434
Signed-off-by: Anton Blanchard <anton@...ba.org>
---
Index: powerpc.git/kernel/trace/trace_stack.c
===================================================================
--- powerpc.git.orig/kernel/trace/trace_stack.c 2010-08-25 11:03:52.337982567 +1000
+++ powerpc.git/kernel/trace/trace_stack.c 2010-08-25 11:03:55.018371055 +1000
@@ -249,7 +249,7 @@ static int trace_lookup_stack(struct seq
{
unsigned long addr = stack_dump_trace[i];
- return seq_printf(m, "%pF\n", (void *)addr);
+ return seq_printf(m, "%pS\n", (void *)addr);
}
static void print_disabled(struct seq_file *m)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists