module license 'unspecified' taints kernel.
2013-01-04 15:11
951 查看
在加载自己写的3.1.4内核的adc驱动时,频频出现下面的错误提示,以前在2.6.29的内核上从未碰到:
[root@LK2440 drivers]# insmod /lib/modules/adc.ko
adc: module license 'unspecified' taints kernel.
Disabling lock debugging due to kernel taint
adc: Unknown symbol platform_get_irq (err 0)
adc: Unknown symbol platform_driver_register (err 0)
adc: Unknown symbol platform_get_resource (err 0)
insmod: cannot insert '/lib/modules/adc.ko': unknown symbol in module or invalid parameter
对于经常写驱动的大牛来说这可能根本不是问题,但是它却困扰我一段时间。反复查阅网上的资料,找到可以从以下几点来解决这个问题,在此记录:
据CSDN的一位网友 daidaiangel 所介绍的:
这是linux kernel 2.6.26 之后版本的bug (详细描述, 请看http://bugzilla.kernel.org/show_bug.cgi?id=12446)
并且这个bug不会被fix
解决办法是把mod_a的Module.symvers放到mod_b的当前路径,从而编译mod_b,符号信息会自动连接进去.
或者在mod_b的makefile中使用KBUILD_EXTRA_SYMBOLS指定mod_a的Module.symvers, 如:
KBUILD_EXTRA_SYMBOLS=/mod_a/Module.symvers
编译mod_b时,搜索Module.symvers的路径是:
1, kernel source path, e.g. /usr/src/kernels/linux-2.6.28.10
2, makefile中M=所指定的路径, 它等效于变量KBUILD_EXTMOD的值
3, 变量KBUILD_EXTRA_SYMBOLS的值
我按照上面所叙述的对我的内核模块的Makefile 做了修改,在编译命令那行加了“KBUILD_EXTRA_SYMBOLS=/linux-3.1.4/Module.symvers”参数,编译问题仍没解决。我想细心地朋友,也许发现了问题根本所在,adc: module license 'unspecified' taints kernel.
对,主要问题就是没有模块许可证声明。而我在添加MODULE_LICENSE("GPL"); 后问题解决了。
[root@LK2440 drivers]# insmod /lib/modules/adc.ko
adc: module license 'unspecified' taints kernel.
Disabling lock debugging due to kernel taint
adc: Unknown symbol platform_get_irq (err 0)
adc: Unknown symbol platform_driver_register (err 0)
adc: Unknown symbol platform_get_resource (err 0)
insmod: cannot insert '/lib/modules/adc.ko': unknown symbol in module or invalid parameter
对于经常写驱动的大牛来说这可能根本不是问题,但是它却困扰我一段时间。反复查阅网上的资料,找到可以从以下几点来解决这个问题,在此记录:
据CSDN的一位网友 daidaiangel 所介绍的:
这是linux kernel 2.6.26 之后版本的bug (详细描述, 请看http://bugzilla.kernel.org/show_bug.cgi?id=12446)
并且这个bug不会被fix
解决办法是把mod_a的Module.symvers放到mod_b的当前路径,从而编译mod_b,符号信息会自动连接进去.
或者在mod_b的makefile中使用KBUILD_EXTRA_SYMBOLS指定mod_a的Module.symvers, 如:
KBUILD_EXTRA_SYMBOLS=/mod_a/Module.symvers
编译mod_b时,搜索Module.symvers的路径是:
1, kernel source path, e.g. /usr/src/kernels/linux-2.6.28.10
2, makefile中M=所指定的路径, 它等效于变量KBUILD_EXTMOD的值
3, 变量KBUILD_EXTRA_SYMBOLS的值
我按照上面所叙述的对我的内核模块的Makefile 做了修改,在编译命令那行加了“KBUILD_EXTRA_SYMBOLS=/linux-3.1.4/Module.symvers”参数,编译问题仍没解决。我想细心地朋友,也许发现了问题根本所在,adc: module license 'unspecified' taints kernel.
对,主要问题就是没有模块许可证声明。而我在添加MODULE_LICENSE("GPL"); 后问题解决了。
相关文章推荐
- hello: module license 'unspecified' taints kernel.
- insmod时出现module license 'unspecified' taints kernel
- module license 'unspecified' taints kernel解决
- module license 'unspecified' taints kernel
- Android unspecified' depends on one or more Android Libraries but is a jar 的解决方法
- erlang nif windows x64 Failed to load NIF library : 'Unspecified error'
- GETBOUNDINGCLIENTRECT CAUSES 'UNSPECIFIED ERROR' IN IE7 AFTER AJAX in Jquery 1.4.2
- Windows Installer Cleanup卸载清理错误提示:Run-time error '-2147024882 (8007000e)' System Error &H80004005 (-2147467259). Unspecified er
- `QtValidLicenseForCoreModule' does not name a type 错误的解决
- Android 编译2.6.36的kernel akm8975 driver时unknown field 'ioctl' specified in initializer的问题
- monogame Unable to load DLL 'openal32.dll': The specified module could not be found
- org.apache.commons.beanutils.ConversionException: No value specified for 'Date'
- ERROR 1449 (HY000): The user specified as a definer ('root'@'%') does not exist
- 警告: No configuration found for the specified action: 'checkLogin' in namespace: ''.的解决办法
- insmod问题: init_module xxxxx.ko' failed (Operation not permitted)
- Umbrella Header for Module Bolts does not include header 'XXXXXX.h'?
- 'VC98mfclib' specified in 'LIB environment variable' 系统找不到指定路
- python模块以及导入出现ImportError: No module named 'xxx'问题
- 彻底解决'Invalid controller specified'(转载)
- Sencha Touch 2: 'specified Store cannot be found'