1,编译好的,insmod加载出错
[143473.044448] dm_cache: Unknown symbol destroy_workqueue (err 0)
[143473.046494] dm_cache: Unknown symbol __alloc_workqueue_key (err 0)
[143481.209699] dm_cache: Unknown symbol destroy_workqueue (err 0)
[143481.211064] dm_cache: Unknown symbol __alloc_workqueue_key (err 0)
[144428.321981] dm_cache: Unknown symbol destroy_workqueue (err 0)
[144428.323584] dm_cache: Unknown symbol __alloc_workqueue_key (err 0)
[144744.910816] dcache: Unknown symbol destroy_workqueue (err 0)
[144744.913719] dcache: Unknown symbol __alloc_workqueue_key (err 0)
原因分析:
这个函数在内核代码中有定义(/drivers/base/Platform.c中)但是还是报错,因为有这一行:EXPORT_SYMBOL_GPL(platform_driver_unregister);
所以为了这个JB许可证,要在我们的代码中加入MODULE_LICENSE(“GPL”);
2,编译通过,加了许可证也是报错。
insmod: error inserting './dcache.ko': -1 Unknown symbol in module
原因分析:
dmesg | tail
错误信息如下
dcache: Unknown symbol destroy_workqueue (err 0)
[144744.913719] dcache: Unknown symbol __alloc_workqueue_key (err 0)
modinfo ./dcache.ko | grep depend
信息为:
dm_mod
说明可能是依赖项目没有加载,我们可以lsmod看下
然后
modprobe dm_mod