我指的是:http://www-users.cs.umn.edu/~boutcher/kprobes/kprobes.txt.html来理解kprobe。我使用了文档中给出的kprobe_example.c。
我使用makefile (取自同一文档的代码)编译了它。
我得到了编译错误,因为我的内核版本是4.2,并且struct pt_regs中的一些字段被更改了。所以我在https://gist.github.com/murlee417/87c2eb43a6afa1954b05404a07813e81的kprobe_example.c中用ip代替了eip,用标志代替了eflag。然后我就可以成功地编译它了。
现在,作为root用户,我做到了:
#insmod kprobe_example.ko我得到了:
insmod: ERROR: could not insert module kprobe_example.ko: Operation not permitted我的消息缓冲区有:
#dmesg
[ 4537.478408] Couldn't find do_fork to plant kprobe请帮助我解决此错误并使insmod正常工作。
发布于 2016-10-06 00:01:45
在x86中,do_fork()称为sys_fork(),因此请按如下所示更改代码
/* For each probe you need to allocate a kprobe structure */
static struct kprobe kp = {
//.symbol_name = "do_fork",
.symbol_name = "sys_fork",
};https://stackoverflow.com/questions/39567227
复制相似问题