diff options
author | Steven Rostedt <rostedt@goodmis.org> | 2012-09-05 10:31:18 -0400 |
---|---|---|
committer | Steven Rostedt <rostedt@goodmis.org> | 2012-09-13 22:52:10 -0400 |
commit | 47d5a5f88b9d25d6464c9b60c28f391e84e3ed65 (patch) | |
tree | 06c348105d6210d7e66a539cea78797f4212e6f1 /arch | |
parent | 4b036d54bf849a75d0103b33d92a53f89ecb9315 (diff) |
ftrace/x86-64: Allow to change RIP in handlers
Allow ftrace handlers to change RIP register (regs->ip)
in handlers. This will allow handlers to call another
function instead of original function.
Link: http://lkml.kernel.org/r/20120905143118.10329.5078.stgit@localhost.localdomain
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/x86/kernel/entry_64.S | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/x86/kernel/entry_64.S b/arch/x86/kernel/entry_64.S index ed767b747fe5..e9cc2b32bdf4 100644 --- a/arch/x86/kernel/entry_64.S +++ b/arch/x86/kernel/entry_64.S | |||
@@ -165,6 +165,10 @@ GLOBAL(ftrace_regs_call) | |||
165 | movq EFLAGS(%rsp), %rax | 165 | movq EFLAGS(%rsp), %rax |
166 | movq %rax, SS(%rsp) | 166 | movq %rax, SS(%rsp) |
167 | 167 | ||
168 | /* Handlers can change the RIP */ | ||
169 | movq RIP(%rsp), %rax | ||
170 | movq %rax, SS+8(%rsp) | ||
171 | |||
168 | /* restore the rest of pt_regs */ | 172 | /* restore the rest of pt_regs */ |
169 | movq R15(%rsp), %r15 | 173 | movq R15(%rsp), %r15 |
170 | movq R14(%rsp), %r14 | 174 | movq R14(%rsp), %r14 |