无法在debian 8中insmod hello_world内核模块

问题描述 投票:0回答:2

我无法理解为什么insmod给Invalid parameters错误(在dmesg中看不到任何东西):

$ sudo insmod hello.ko
insmod: ERROR: could not insert module hello.ko: Invalid parameters

$ sudo insmod /hello.ko
insmod: ERROR: could not load module /hello.ko: No such file or directory

我的模块中没有参数。这只是你好世界的例子。

我的环境:

$ uname -r
3.16.0-4-amd64

我已经安装了所有可能的内核头文件包:

linux-headers-3.16.0-4-all
linux-headers-3.16.0-4-all-amd64
linux-headers-3.16.0-4-amd64
linux-headers-3.16.0-4-common
linux-headers-amd64 

我的代码:

#include <linux/module.h>   /* Needed by all modules */
#include <linux/kernel.h>   /* Needed for KERN_INFO */

int init_module(void)
{
    printk(KERN_INFO "Hello world 1.\n");
    return 0;
}

void cleanup_module(void)
{
    printk(KERN_INFO "Goodbye world 1.\n");
}

MODULE_LICENSE("GPL");

我使用以下Makefile

obj-m += hello.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

make输出:

$ make

make -C /lib/modules/3.16.0-4-amd64/build M=/home/user/c.driver/driver-1 modules
make[1]: Entering directory '/usr/src/linux-headers-3.16.0-4-amd64'
Makefile:10: *** mixed implicit and normal rules: deprecated syntax
make[1]: Entering directory `/usr/src/linux-headers-3.16.0-4-amd64'
  CC [M]  /home/user/c.driver/driver-1/hello.o
  Building modules, stage 2.
  MODPOST 1 modules
  CC      /home/user/c.driver/driver-1/hello.mod.o
  LD [M]  /home/user/c.driver/driver-1/hello.ko
make[1]: Leaving directory '/usr/src/linux-headers-3.16.0-4-amd64'

更新:与14.04.1-Ubuntu相同的结果

linux makefile kernel-module insmod
2个回答
0
投票

也许是因为你忘记了:

module_init(init_module);                                                           
module_exit(cleanup_module);

我通常将init_module()和cleanup_module()声明为静态函数。和同伴代码是我的内核模块模板:

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

static int init_module(void)
{
   ... 
   return 0;
}

static void exit_module(void)
{
   ...
}

module_init(init_module);
module_exit(exit_module);
MODULE_LICENSE("GPL");

0
投票

对我来说,问题是该模块文件位于共享文件夹中(事实上,我的Ubuntu框是Parallels上的VM)。将模块复制到本地文件夹,然后重试。

感谢@avasin为此。答案是在评论中,但没有快速找到,所以在这里添加它可能有助于其他人。这让我筋疲力尽了几个小时。

© www.soinside.com 2019 - 2024. All rights reserved.