今年打算好好学学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 <[email protected]>"); 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 //可以查看日志信息