Commit 91fc862c authored by Masami Hiramatsu's avatar Masami Hiramatsu Committed by Jon Medhurst

arm: kprobes: Skip single-stepping in recursing path if possible

Kprobes/arm skips single-stepping (moreover handling the event)
if the conditional instruction must not be executed. This
also apply the rule when we hit the recursing kprobe, so
that kprobe does not count nmissed up in that case.
Signed-off-by: default avatarMasami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: default avatarJon Medhurst <tixy@linaro.org>
parent f3fbd7ec
...@@ -266,7 +266,15 @@ void __kprobes kprobe_handler(struct pt_regs *regs) ...@@ -266,7 +266,15 @@ void __kprobes kprobe_handler(struct pt_regs *regs)
#endif #endif
if (p) { if (p) {
if (cur) { if (!p->ainsn.insn_check_cc(regs->ARM_cpsr)) {
/*
* Probe hit but conditional execution check failed,
* so just skip the instruction and continue as if
* nothing had happened.
* In this case, we can skip recursing check too.
*/
singlestep_skip(p, regs);
} else if (cur) {
/* Kprobe is pending, so we're recursing. */ /* Kprobe is pending, so we're recursing. */
switch (kcb->kprobe_status) { switch (kcb->kprobe_status) {
case KPROBE_HIT_ACTIVE: case KPROBE_HIT_ACTIVE:
...@@ -289,7 +297,7 @@ void __kprobes kprobe_handler(struct pt_regs *regs) ...@@ -289,7 +297,7 @@ void __kprobes kprobe_handler(struct pt_regs *regs)
/* impossible cases */ /* impossible cases */
BUG(); BUG();
} }
} else if (p->ainsn.insn_check_cc(regs->ARM_cpsr)) { } else {
/* Probe hit and conditional execution check ok. */ /* Probe hit and conditional execution check ok. */
set_current_kprobe(p); set_current_kprobe(p);
kcb->kprobe_status = KPROBE_HIT_ACTIVE; kcb->kprobe_status = KPROBE_HIT_ACTIVE;
...@@ -310,13 +318,6 @@ void __kprobes kprobe_handler(struct pt_regs *regs) ...@@ -310,13 +318,6 @@ void __kprobes kprobe_handler(struct pt_regs *regs)
} }
reset_current_kprobe(); reset_current_kprobe();
} }
} else {
/*
* Probe hit but conditional execution check failed,
* so just skip the instruction and continue as if
* nothing had happened.
*/
singlestep_skip(p, regs);
} }
} else if (cur) { } else if (cur) {
/* We probably hit a jprobe. Call its break handler. */ /* We probably hit a jprobe. Call its break handler. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment