错误:无法插入模块无效的模块格式

时间:2015-11-05 05:31:48

标签: c linux kernel-module insmod

root @ vm #insmod ./test01.ko

insmod: ERROR: could not insert module ./tes01.ko: Invalid module format

我的c文件test01.c

#include <linux/module.h>
#include <linux/kernel.h>

int init_module(void)
{
    printk(KERN_INFO "Hello World!");
    return 0;
}

void cleanup_module(void)
{
    printk(KERN_INFO "Unloading test01 module\n");
}

基于模块的test01.c

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>

static int __init load_module(void)
{
    printk(KERN_INFO "Hello World!");
    return 0;
}

static void __exit unload_module(void)
{
    printk(KERN_INFO "Unloading test01 module\n");
}

module_init(load_module);
module_exit(unload_module);

生成文件

obj-m += test01.o

all:
    make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules

clean:
    make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

使工作正常 modinfo的输出

root@vm$ modinfo test01.ko
filename:       /test01/test01.ko
srcversion:     5AF577C6F26F6B146320283
depends:        
vermagic:       4.0.0-rc5+ SMP mod_unload modversions 

我的内核版本uname -a

3.19.0-rc1+

dmseg输出

[ 1470.217197] test01: disagrees about version of symbol module_layout

我觉得问题是我的vermagic来自modinfo是4.0而内核版本是3.19。一段时间后我编译了内核源代码(不知道哪个)并且还通过make -j2 && sudo make modules_install安装它

我不知道为什么内核版本不匹配?

0 个答案:

没有答案