|
@@ -897,9 +897,10 @@ int __kprobes kprobe_fault_handler(struct pt_regs *regs, int trapnr)
|
|
|
struct kprobe *cur = kprobe_running();
|
|
|
struct kprobe_ctlblk *kcb = get_kprobe_ctlblk();
|
|
|
|
|
|
- switch (kcb->kprobe_status) {
|
|
|
- case KPROBE_HIT_SS:
|
|
|
- case KPROBE_REENTER:
|
|
|
+ if (unlikely(regs->ip == (unsigned long)cur->ainsn.insn)) {
|
|
|
+ /* This must happen on single-stepping */
|
|
|
+ WARN_ON(kcb->kprobe_status != KPROBE_HIT_SS &&
|
|
|
+ kcb->kprobe_status != KPROBE_REENTER);
|
|
|
/*
|
|
|
* We are here because the instruction being single
|
|
|
* stepped caused a page fault. We reset the current
|
|
@@ -914,9 +915,8 @@ int __kprobes kprobe_fault_handler(struct pt_regs *regs, int trapnr)
|
|
|
else
|
|
|
reset_current_kprobe();
|
|
|
preempt_enable_no_resched();
|
|
|
- break;
|
|
|
- case KPROBE_HIT_ACTIVE:
|
|
|
- case KPROBE_HIT_SSDONE:
|
|
|
+ } else if (kcb->kprobe_status == KPROBE_HIT_ACTIVE ||
|
|
|
+ kcb->kprobe_status == KPROBE_HIT_SSDONE) {
|
|
|
/*
|
|
|
* We increment the nmissed count for accounting,
|
|
|
* we can also use npre/npostfault count for accounting
|
|
@@ -945,10 +945,8 @@ int __kprobes kprobe_fault_handler(struct pt_regs *regs, int trapnr)
|
|
|
* fixup routine could not handle it,
|
|
|
* Let do_page_fault() fix it.
|
|
|
*/
|
|
|
- break;
|
|
|
- default:
|
|
|
- break;
|
|
|
}
|
|
|
+
|
|
|
return 0;
|
|
|
}
|
|
|
|