aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kernel/entry_32.S
diff options
context:
space:
mode:
authorAbhishek Sagar <sagar.abhishek@gmail.com>2008-06-21 14:17:27 -0400
committerIngo Molnar <mingo@elte.hu>2008-06-23 16:10:56 -0400
commit395a59d0f8e86bb39cd700c3d185d30c670bb958 (patch)
tree1558e635efcede901c5dbe9acd625d475db5b369 /arch/powerpc/kernel/entry_32.S
parentf34bfb1beef8a17ba3d46b60f8fa19ffedc1ed8d (diff)
ftrace: store mcount address in rec->ip
Record the address of the mcount call-site. Currently all archs except sparc64 record the address of the instruction following the mcount call-site. Some general cleanups are entailed. Storing mcount addresses in rec->ip enables looking them up in the kprobe hash table later on to check if they're kprobe'd. Signed-off-by: Abhishek Sagar <sagar.abhishek@gmail.com> Cc: davem@davemloft.net Cc: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/powerpc/kernel/entry_32.S')
-rw-r--r--arch/powerpc/kernel/entry_32.S4
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/entry_32.S b/arch/powerpc/kernel/entry_32.S
index 3b1dd29d9f91..7231a708af0d 100644
--- a/arch/powerpc/kernel/entry_32.S
+++ b/arch/powerpc/kernel/entry_32.S
@@ -30,6 +30,7 @@
30#include <asm/ppc_asm.h> 30#include <asm/ppc_asm.h>
31#include <asm/asm-offsets.h> 31#include <asm/asm-offsets.h>
32#include <asm/unistd.h> 32#include <asm/unistd.h>
33#include <asm/ftrace.h>
33 34
34#undef SHOW_SYSCALLS 35#undef SHOW_SYSCALLS
35#undef SHOW_SYSCALLS_TASK 36#undef SHOW_SYSCALLS_TASK
@@ -1053,6 +1054,7 @@ _GLOBAL(_mcount)
1053 stw r10,40(r1) 1054 stw r10,40(r1)
1054 stw r3, 44(r1) 1055 stw r3, 44(r1)
1055 stw r5, 8(r1) 1056 stw r5, 8(r1)
1057 subi r3, r3, MCOUNT_INSN_SIZE
1056 .globl mcount_call 1058 .globl mcount_call
1057mcount_call: 1059mcount_call:
1058 bl ftrace_stub 1060 bl ftrace_stub
@@ -1090,6 +1092,7 @@ _GLOBAL(ftrace_caller)
1090 stw r10,40(r1) 1092 stw r10,40(r1)
1091 stw r3, 44(r1) 1093 stw r3, 44(r1)
1092 stw r5, 8(r1) 1094 stw r5, 8(r1)
1095 subi r3, r3, MCOUNT_INSN_SIZE
1093.globl ftrace_call 1096.globl ftrace_call
1094ftrace_call: 1097ftrace_call:
1095 bl ftrace_stub 1098 bl ftrace_stub
@@ -1128,6 +1131,7 @@ _GLOBAL(_mcount)
1128 stw r3, 44(r1) 1131 stw r3, 44(r1)
1129 stw r5, 8(r1) 1132 stw r5, 8(r1)
1130 1133
1134 subi r3, r3, MCOUNT_INSN_SIZE
1131 LOAD_REG_ADDR(r5, ftrace_trace_function) 1135 LOAD_REG_ADDR(r5, ftrace_trace_function)
1132 lwz r5,0(r5) 1136 lwz r5,0(r5)
1133 1137