|
@@ -858,15 +858,15 @@ static int __kprobes post_kprobe_handler(struct pt_regs *regs)
|
|
|
if (!cur)
|
|
|
return 0;
|
|
|
|
|
|
+ resume_execution(cur, regs, kcb);
|
|
|
+ regs->flags |= kcb->kprobe_saved_flags;
|
|
|
+ trace_hardirqs_fixup_flags(regs->flags);
|
|
|
+
|
|
|
if ((kcb->kprobe_status != KPROBE_REENTER) && cur->post_handler) {
|
|
|
kcb->kprobe_status = KPROBE_HIT_SSDONE;
|
|
|
cur->post_handler(cur, regs, 0);
|
|
|
}
|
|
|
|
|
|
- resume_execution(cur, regs, kcb);
|
|
|
- regs->flags |= kcb->kprobe_saved_flags;
|
|
|
- trace_hardirqs_fixup_flags(regs->flags);
|
|
|
-
|
|
|
/* Restore back the original saved kprobes variables and continue. */
|
|
|
if (kcb->kprobe_status == KPROBE_REENTER) {
|
|
|
restore_previous_kprobe(kcb);
|