红联Linux门户
Linux帮助

linux内核模块编程helloworld小程序问题解决方法

发布时间:2008-10-17 00:53:44来源:红联作者:Montun
作者:软件小作坊

首先声明下,对linux也是刚入门。没系统的学习过linux。

首先附上能编译通过的hello world程序。[code]//#ifndef __KERNEL__
//#define __KERNEL__
//#endif //见别人的程序里出现过 注释掉也能通过。
#ifndef MODULE
#define MODULE
#endif

#include
MODULE_LICENSE("GPL");

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

void cleanup_module(void){
printk("<0>Goodbye World!");
}[/code]编译程序可能会出现的问题:

若直接用命令gcc -c hello.c编译(声明下文件名为hello.c),则可能会出现以下提示:

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.

解决办法: 加-I选项即:gcc -I/usr/src/linux-2.4.20-8/include/ -c hello.c -o hello.o

程序里还需要有这么一句 MODULE_LICENSE("GPL");否则出现以下警告信息,但模块已经加载

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

注意问题:加载模块命令参数和卸载模块命令参数有一点点不同哦

加载模块:insmod hello.o

卸载模块:rmmod hello 注意后面没有点偶哦(.o)

某些时候用insmod -f能够强制成功加载,需谨慎使用。

打印消息受级别的限制,消息级别可以通过printk设置,上面给出的代码设置级别为第0级,数字越小级别越高。

如果看不到用printk打印的信息,将级别设置为0级应该就可以了,也可以用dmesg命令查看。

i.e. 察看加载模块打印信息:首先执行命令insmod hello.o回车,然后再给一条命令dmesg即可。卸载模块类似。呵呵。
文章评论

共有 4 条评论

  1. forch 于 2011-05-26 16:05:44发表:

    没有linux-2.4.20-8源码包可以解压,可以给个连接或者发送一个不?用LDD2自带的Makefile编译,如何解决这个问题?

  2. luoxiangyun 于 2009-01-21 13:53:41发表:

    我要写的也是这个,可是出了很多问题

  3. wwq119119 于 2008-10-23 00:35:11发表:

    刚学习,看看

  4. chris078426 于 2008-10-17 09:37:40发表:

    你怎么没有说是哪个内核呀,这样的应该是2。4内核的。:0wfd1d