今年打算好好学学Linux下内核的开发,不过万事开头难,第一步当然是学着编译内核,试验了好多次都是失败告终,昨天终于第一次在虚拟机上升级内核成功,今天就先来试着写个hello world的程序,和编写Linux下的应用程序差别还是很大的。
#include<linux/module.h>
#include<linux/init.h>
int __init hello_init (void)
{
printk("HelloWorld\n");
return 0;
}
void __exit hello_exit(void)
{
printk("GoodBye\n");
}
MODULE_AUTHOR("wanghaifeng <haifengwang1987@gmail.com>");
MODULE_DESCRIPTION("hello");
MODULE_LICENSE("GPL");
module_init(hello_init);
module_exit(hello_exit);这是很简单的一个的内核模块代码,没有main函数,编译的方式不能用gcc的常规方式。模块调用module_init()和module_exit()将该模块注册到内核。每个模块都有初始化函数和退出函数。下面需要对这个内核模块进行编译,新建一个Makefile文件。文件的内容如下
obj-m :=hello.o下面就可以进行编译了,编译的环境是RedHat5.3,内核版本是2.6.18-53.el5,使用下面的命令进行编译:
# make -C /usr/src/kernels/2.6.18-53.el5-i686/ modules M=$PWD
make: Entering directory `/usr/src/kernels/2.6.18-53.el5-i686'
Building modules, stage 2.
MODPOST
make: Leaving directory `/usr/src/kernels/2.6.18-53.el5-i686'
可以看到目录里多了几个文件,编译成功,hello.ko就是生成的内核模块。
# ls
hello.c hello.ko hello.mod.c hello.mod.o hello.o Makefile Module.symvers
使用insmod,lsmod,rmmod可以装载,查看,卸载内核模块,printk输出的信息将会打印到日志里面/var/log/messages
# insmod hello.ko //插入模块,会调用hello_init()
# lsmod | grep -e hello -e Module //查看模块
Module Size Used by
hello 5632 0
# rmmod hello //删除模块,会调用hello_exit()
# tail -f /var/log/messages //可以查看日志信息