标签:
Linux模块是一些可以作为独立程序来编译的函数和数据类型的集合。之所以提供模块机制,是因为Linux本身是一个单内核。单内核由于所有内容都集成在一起,效率很高,但可扩展性和可维护性相对较差,模块机制可弥补这一缺陷。
Linux模块可以通过静态或动态的方法加载到内核空间,静态加载是指在内核启动过程中加载;动态加载是指在内核运行的过程中随时加载。
一个模块被加载到内核中时,就成为内核代码的一部分。模块加载入系统时,系统修改内核中的符号表,将新加载的模块提供的资源和符号添加到内核符号表中,以便模块间的通信。
1)模块构造函数:执行insmod或modprobe指令加载内核模块时会调用的初始化函数。函数原型必须是module_init(),括号内是函数指针
2)模块析构函数:执行rmmod指令卸载模块时调用的函数。函数原型是module_exit()
3)模块许可声明:函数原型是MODULE_LICENSE(),告诉内核该程序使用的许可证,不然在加载时它会提示该模块污染内核。一般会写GPL。
头文件module.h,必须包含此文件; 头文件kernel.h,包含常用的内核函数; 头文件init.h包含宏_init和_exit,允许释放内核占用的内存。
实践代码:
编写makefile文件。如下是根据自己情况改写的:
第一行的printname换成你自己写的.c文件名。 第三行的LINUX_KERNEL_PATH为自己的内核版本对应的内核源码包地址 make -C $(LINUX_KERNEL_PATH) 指明跳转到内核源码目录下读取那里的Makefile M=$(CURRENT_PATH) 表明返回到当前目录继续执行当前的Makefile。
编译执行过程我们都会了就不写了。
sudo insmod printname.ko
dmesg看内核信息
sudo rmmod printname
这时用dmesg看内核信息,就会看到写在module_exit()中的输出。
在上一个代码的基础上,修改代码。
for_each_process()是一个宏,定义如下:
即for循环,从第一个PCB(叫做init_task)开始,顺着next指针遍历。
修改Makefile,make,insmod。
做了模块部分的实践,掌握了几个重要的命令操作。知道了如何装载模块等等。我把一些做实验必须用到的素材和步骤记录下来。其他详解能理解的就不赘述了。这方面的实践要不要继续做下去呢,让我看看接下来的课程安排再做计划。看看是要做别的实践任务还是要深入做。
标签:
原文地址:http://www.cnblogs.com/paperfish/p/5517799.html