kprobe pre_handler change return IP
From: Liuyongan
Date: Thu Oct 17 2013 - 08:57:55 EST
I use kprobe to probe a function suppose:
int is_winter(int num) { ... }
int replace_is_winter(int num) { ...}
I want to replace is_winter() with replace_is_winter(), so when we call is_winter, replace_is_winter will be called.
so:
int my_pre_handler(struct kprobe *p, struct pt_regs *regs)
{
regs->ip = (unsigned long)&replace_is_winter;
return 1;
}
and echo 0 > /proc/sys/debug/kprobes-optimization so that jump instruction will not be used.
I got a exception in fault_handler, and trap number is 14.
fault_handler: p->addr = 0xffffffffa08e201a, ip = ffffffff8021c59d, trap #14n
Anyone here can help me ?
èº{.nÇ+·®+%Ëlzwm
ébëæìr¸zX§»®w¥{ayºÊÚë,j¢f£¢·hàz¹®w¥¢¸¢·¦j:+v¨wèjØm¶ÿ¾«êçzZ+ùÝj"ú!¶iOæ¬z·vØ^¶m§ÿðÃnÆàþY&