Linux插入模块时提示Killed

模块开发的时候,插入模块时,可能经常会遇到Killed的情况,具体情况如下图所示:

这个时候基本就可以确定是代码有bug,或者自己修改的内核代码部分有bug由模块去调用时,导致插入模块时失败了。

使用dmesg查看一下报错信息:

Linux插入模块时提示Killed_第1张图片

使用dmesg基本可以看到报错信息,注意观察dmesg打印出的标红的信息,这一般就是报错信息。

从上图中我遇到的报错信息来看,错误来自我的函数slide_win_init

再结合后面的报错信息来看,基本可以确定是空指针异常的问题,有可能会有具体报错:null pointer之类的,所以先进入到该函数查看其中是否有空指针,是否没有为内容开辟内存空间等。

进入到报错的函数,通过分析发现,确实有结构体指针没有开辟内存空间,从而导致了这个错误,将空间开辟好,重新编译模块问题解决。

总结

1、插入模块时遇到Killed不要慌,dmesg先把信息打,通过打印出的标红信息进行排查。

2、这种情况大概率是空指针的问题,结合报错信息在相应的函数中进行排查,是否有空指针的问题,如果有空指针没开辟空间使用kmalloc或者vmalloc开辟内核内存空间。

你可能感兴趣的:(linux报错与解决)