2007年9月12日星期三

[linux,内核编程]insmod时的内核版本问题的解决方案

[linux,内核编程]insmod时的内核版本问题的解决方案

分类:技术笔记

03-27-2004, 10:46 AM

本篇文章是我在Linux 操作系统上实现内核模块编译平台的笔记,现在记录下来希望对碰到和我一样问题的朋友有帮助。
首先vi hello.c
原程序来自:
#include
#include
#if CONFIG_MODVERSIONS==1
#define MODVERSIONS
#include
#endif


int init_module(void)
{
printk("Hello,World!\n");
return 0;
}

void cleanup_module(void)
{
printk("Goodbye cruel world \n");
}

原书给的makefile:

CC=gcc
MODCFLAGS:=-Wall -DMODULE-D__KERNEL__ -DLINUX
hello.o:hello.c /usr/include/linux/version.h
$(CC) $(MODCFLAGS) -c hello.c
echo insmod
echo rmmod
echo

然后输入make 命令.
然后insmod hello.o
结果出现问题:
hello.o: kernel-module version mismatch
hello.o was compiled for kernel version 2.4.20
while this kernel is version 2.4.20-8.

找了不少资料,总算解决了.
只要在makefile中gcc的参数加上-I /usr/src/linux-2.4.20-8/include (注意:linux-X.X.XX-X请根据自己的机子来配,看看/usr/src/下的linux-?就知道是什么了)

于是makefile改为:
CC=gcc
MODCFLAGS:=-Wall -DMODULE -D__KERNEL__ -DLINUX -I /usr/src/linux-2.4.20-8/include
hello.o:hello.c /usr/include/linux/version.h
$(CC) $(MODCFLAGS) -c hello.c
echo insmod
echo rmmod
echo

然后insmod hello.o出现了第二个问题:

Warning: loading hello.o will taint the kernel: no license
See http://www.tux.org/lkml/#export-tainted for information about tainted modules
Module hello loaded, with warnings


又是找资料,
于是知道了,在原程序中加入MODULE_LICENSE("GPL");
即:
#include
#include
#if CONFIG_MODVERSIONS==1
#define MODVERSIONS
#include
#endif


int init_module(void)
{
MODULE_LICENSE("GPL");
printk("Hello,World!\n");
return 0;
}

void cleanup_module(void)
{
printk("Goodbye cruel world \n");
}

然后make,insmod 都没问题了.

最后:
下面我们来查看这个模块所执行的显示内容,这些内容是不会在终端显示的。要执行命令:

dmesg

来查看。在最下面显示
Hello,World!
Goodbye cruel world
Hello,World!

还有一种方法可以看到这个模块是否加载成功否。

$cat /proc/modules

从中可以看到hello 这个模块,这就是我加载的。
这个文件中的信息分为四列。
第一列:模块名。第二列:模块使用内存的字节数。第三列:模块的当前使用计数。第四列:备注。
好了,我们来卸载这个模块吧。

rmmod hello

再用 dmesg 来查看卸载时发出的信息吧。

没有评论: