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

2019-07-13 02:27发布

将自己编译的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给包括在里面了,宏定义还没有打开。。。 记录下,作为调试的记录