感谢支持
我们一直在努力

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

赞(0) 打赏
转载请注明出处:服务器评测 » Linux内核模块开发之Hello world
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏