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=$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              //可以查看日志信息

相关内容