hello.c文件
//必要的头文件
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
//模块许可证声明(必须)
MODULE_LICENSE("Dual BSD/GPL");
//模块加载函数(必须)
static int hello_init(void)
{
printk(KERN_ALERT "Hello World enter/n");
return 0;
}
//模块卸载函数(必须)
static void hello_exit(void)
{
printk(KERN_ALERT "Hello World exit/n");
}
//模块的注册
module_init(hello_init);
module_exit(hello_exit);
//声明模块的作者(可选)
MODULE_AUTHOR("XXX");
//声明模块的描述(可选)
MODULE_DESCRIPTION("This is a simple example!/n");
//声明模块的别名(可选)
MODULE_ALIAS("A simplest example");
Makefile文件
obj-m += hello.o
#generate the path
CURRENT_PATH:=$(shell pwd)
#the current kernel version number
LINUX_KERNEL:=$(shell uname -r)
#the absolute path
LINUX_KERNEL_PATH:=/usr/src/linux-headers-$(LINUX_KERNEL)
#complie object
all:
make -C $(LINUX_KERNEL_PATH) M=$(CURRENT_PATH) modules
#clean
clean:
make -C $(LINUX_KERNEL_PATH) M=$(CURRENT_PATH) clean
输入命令:sudo insmod hello.ko(注意要用sudo),这时没有任何提示,很多人会很奇怪,刚才不是说过,模块加载后,程序中要对应输出一条提示信息,怎么这里什么都没有。大家不要急,再想一想刚才所用到的打印信息的函数printk(),它与我们平常C库的printf()函数不一样,不是运行在用户界面上的,所以肯定不会在终端上显示出信息。要看信息必须要进入到日志文件中。这时我们再输入命令进到系统日志:dmesg,我们把界面拖到最后,会发现有一条信息,Hello World enter。哈哈,这正是我们所需要的,说明我们刚才编写的模块已经插入到内核当中了。接下来再试一试删除命令,输入命令:sudo rmmod hello.ko,这时跟刚才的插入命令一样,没有什么反应。再输入命令打开系统日志,我们会发现在刚才 Hello World enter命令后面会有一个新的信息Hello World exit,这说明我们的模块卸载成功。
除了加载和删除模块,我们也可以用命令 lsmod 来查看当前系统中加载的所有模块及模块间的依赖关系。如果刚才我们加载了hello模块并没有删除,用这个命令,我们会在其中找到hello这一项,这样也可以说明我们自己编写的模块加载成功。相应的,如果我们删除了该模块,用这个命令后,hello模块不会出现。lsmod命令实际上读取并分析/proc/modules文件。
使用modinfo<模块名>命令可以获得模块的信息,包括模块的作者,说明,参数……也就是我们刚才编写模块时可选的几个部分。
---------------------
作者:冰清
来源:CSDN
原文:https://blog.csdn.net/bingqing07/article/details/5888875
版权声明:本文为博主原创文章,转载请附上博文链接!