您的位置:首页 > 其它

insmod: error inserting 'hello.ko': -1 Invalid module format

2013-01-23 14:22 459 查看
转载自:http://www.linuxdiyf.com/viewarticle.php?id=105558

平时加载都正常的驱动,今天竟然加载失败,看来把驱动写进内核部分,会省掉这种麻烦。

insmod: error inserting 'hello.ko': -1 Invalid module format

一些不那么神秘的信息被纪录在文件/var/log/messages中;

Jun 4 22:07:54 localhost kernel: hello: version magic '2.6.5-1.358custom 686

REGPARM 4KSTACKS gcc-3.3' should be '2.6.5-1.358 686 REGPARM 4KSTACKS gcc-3.3'

换句话说,内核拒绝加载你的模块因为记载版本号的字符串不符(更确切的说是版本印戳)。版本印戳作为一个静态的字符串存在于内核模块中,以 vermagic:。版本信息是在连接阶段从文件init/vermagic.o中获得的。查看版本印戳和其它在模块中的一些字符信息,可以使用下面的命令 modinfo module.ko:

[root@pcsenonsrv 02-HelloWorld]# modinfo hello-4.ko

license: GPL

author: Peter Jay Salzman <p@dirac.org>

descrīption: A sample driver

vermagic: 2.6.5-1.358 686 REGPARM 4KSTACKS gcc-3.3

depends:

我们可以借助选项--force-vermagic解决该问题,但这种方法有潜在的危险,所以在成熟的模块中也是不可接受的。

首先,准备同你目前的内核版本完全一致的内核代码树。然后,找到你的当前内核的编译配置文件。通常它可以在路径 /boot下找到,使用像config-2.6.x的文件名。你可以直接将它拷贝到内核代码树的路径下: cp /boot/config-`uname -r` /usr/src/linux-`uname -r`/.config。

即使使用完全相同的配置文件,版本印戳还是有细小的差异的,但这足以导致模块加载的失败。这其中的差异就是在模块中出现却不在内核中出现的custom字符串,是由某些发行版提供的修改过的 makefile导致的。检查/usr/src/linux/Makefile,确保下面这些特定的版本信息同你使用的内核完全一致:

VERSION = 2

PATCHLEVEL = 6

SUBLEVEL = 5

EXTRAVERSION = -1.358custom

...

不必完全编译一遍内核,只得到需要的文件即可:

root@pcsenonsrv linux-2.6.x]# make

CHK include/linux/version.h

UPD include/linux/version.h

SYMLINK include/asm -> include/asm-i386

SPLIT include/linux/autoconf.h -> include/config/*

HOSTCC scrīpts/basic/fixdep

HOSTCC scrīpts/basic/split-include

HOSTCC scrīpts/basic/docproc

HOSTCC scrīpts/conmakehash

HOSTCC scrīpts/kallsyms

CC scrīpts/empty.o

...

如果你不是确实想编译一个内核,你可以在SPLIT后通过按下CTRL-C中止编译过程。因为此时你需要的文件已经就绪了。现在你可以返回你的模块目录然后编译加载它:此时模块将完全针对你的当前内核编译,加载时也不会由任何错误提示。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐