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

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

首先附上能编译通过的hello world程序。

//#ifndef __KERNEL__
//#define __KERNEL__
//#endif //见别人的程序里出现过 注释掉也能通过。
#ifndef MODULE
#define MODULE
#endif

#include <Linux/module.h>
MODULE_LICENSE("GPL");

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

void cleanup_module(void){
printk("<0>Goodbye World!");
}


编译程序可能会出现的问题:

若直接用命令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 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即可。卸载模块类似。呵呵。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wzygxs.html