Linux内核模块开发之Hello world

今年打算好好学学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=$PWDmake: Entering directory `/usr/src/kernels/2.6.18-53.el5-i686′ Building modules, stage 2. MODPOSTmake: Leaving directory `/usr/src/kernels/2.6.18-53.el5-i686′

可以看到目录里多了几个文件,编译成功,hello.ko就是生成的内核模块。

# lshello.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 byhello 5632 0

# rmmod hello //删除模块,会调用hello_exit()

# tail -f /var/log/messages //可以查看日志信息

绚丽的民族风情,悠久的历史文化。抛开尘世的纷扰,

Linux内核模块开发之Hello world

相关文章:

你感兴趣的文章:

标签云: