首先声明下,对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即可。卸载模块类似。呵呵。