嵌入式linux 内核模块调试ko的 insmod问题

来源:互联网 发布:淘宝客服用的打字软件 编辑:程序博客网 时间:2024/05/18 17:42
将自己编译的drv_fpga.ko 进行insmod后,内核中的init函数中的打印信息没有打印出来。lsmod显示已经安装成功,但是在/proc/misc/目录下(设备注册到了该目录下)没有找到对应的设备,
objdump -sj.modinfo drv_fpga 显示如下信息,感觉ko文件是有问题的。

通过以下方法逐一排查
1.肯定是没有调到module_init中自己注册的init函数,因为打印信息没有打印出(打印级别肯定没问题)
2.从上面的调试信息看,ko肯定没有注册到内核,因为/proc/misc下没有该设备,虽然lsmod存在该ko
3.ko文件肯定存在问题,因为用objdump查看的信息和正常的ko信息是不一样的,正常的ko信息格式如下,ko的信息非常全面

好吧,最后发现是自己的宏定义把MODULE_LICENSE给包括在里面了,宏定义还没有打开。。。
记录下,作为调试的记录
0 0
原创粉丝点击