将自己编译的drv_fpga.ko 进行insmod后,内核中的init函数中的打印信息没有打印出来。lsmod显示已经安装成功,但是在/proc/misc/目录下(设备注册到了该目录下)没有找到对应的设备,
objdump -sj.modinfo drv_fpga 显示如下信息,感觉ko文件是有问题的。
![](data/attach/1907/ck695nmyd64si1sjklp0yjzzuph42e5g.jpg)
通过以下方法逐一排查
1.肯定是没有调到module_init中自己注册的init函数,因为打印信息没有打印出(打印级别肯定没问题)
2.从上面的调试信息看,ko肯定没有注册到内核,因为/proc/misc下没有该设备,虽然lsmod存在该ko
3.ko文件肯定存在问题,因为用objdump查看的信息和正常的ko信息是不一样的,正常的ko信息格式如下,ko的信息非常全面
![](data/attach/1907/u9b0j1y8pjxe2o2d7k9uiucd16b899qo.jpg)
好吧,最后发现是自己的宏定义把MODULE_LICENSE给包括在里面了,宏定义还没有打开。。。
记录下,作为调试的记录