For KPROBES_ON_FTRACE case, we need to adjust the kprobe's addr
correspondingly.

Signed-off-by: Jisheng Zhang <jisheng.zh...@synaptics.com>
---
 kernel/kprobes.c | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/kernel/kprobes.c b/kernel/kprobes.c
index 9873fc627d61..f8400753a8a9 100644
--- a/kernel/kprobes.c
+++ b/kernel/kprobes.c
@@ -1560,6 +1560,9 @@ int register_kprobe(struct kprobe *p)
        addr = kprobe_addr(p);
        if (IS_ERR(addr))
                return PTR_ERR(addr);
+#ifdef CONFIG_KPROBES_ON_FTRACE
+       addr = (kprobe_opcode_t *)ftrace_call_adjust((unsigned long)addr);
+#endif
        p->addr = addr;
 
        ret = check_kprobe_rereg(p);
-- 
2.23.0.rc1

Reply via email to