2.10. 快速参考

最后更新于:2022-04-01 02:56:18

## 2.10. 快速参考 本节总结了我们在本章接触到的内核函数, 变量, 宏定义, 和 /proc 文件. 它的用意是作为一个参考. 每一项列都在相关头文件的后面, 如果有. 从这里开始, 在几乎每章的结尾会有类似一节, 总结一章中介绍的新符号. 本节中的项通常以在本章中出现的顺序排列: ~~~ insmod modprobe rmmod ~~~ 用户空间工具, 加载模块到运行中的内核以及去除它们. ~~~ #include <linux/init.h> module_init(init_function); module_exit(cleanup_function); ~~~ 指定模块的初始化和清理函数的宏定义. ~~~ __init __initdata __exit __exitdata ~~~ 函数( __init 和 __exit )和数据 (__initdata 和 __exitdata)的标记, 只用在模块初始化或者清理时间. 为初始化所标识的项可能会在初始化完成后丢弃; 退出的项可能被丢弃如果内核没有配置模块卸载. 这些标记通过使相关的目标在可执行文件的特定的 ELF 节里被替换来工作. ~~~ #include <linux/sched.h> ~~~ 最重要的头文件中的一个. 这个文件包含很多驱动使用的内核 API 的定义, 包括睡眠函数和许多变量声明. ~~~ struct task_struct *current; ~~~ 当前进程. ~~~ current->pidcurrent->comm ~~~ 进程 ID 和 当前进程的命令名. obj-m 一个 makefile 符号, 内核建立系统用来决定当前目录下的哪个模块应当被建立. ~~~ /sys/module /proc/modules ~~~ /sys/module 是一个 sysfs 目录层次, 包含当前加载模块的信息. /proc/moudles 是旧式的, 那种信息的单个文件版本. 其中的条目包含了模块名, 每个模块占用的内存数量, 以及使用计数. 另外的字串追加到每行的末尾来指定标志, 对这个模块当前是活动的. vermagic.o 来自内核源码目录的目标文件, 描述一个模块为之建立的环境. ~~~ #include <linux/module.h> ~~~ 必需的头文件. 它必须在一个模块源码中包含. ~~~ #include <linux/version.h> ~~~ 头文件, 包含在建立的内核版本信息. ~~~ LINUX_VERSION_CODE ~~~ 整型宏定义, 对 #ifdef 版本依赖有用. ~~~ EXPORT_SYMBOL (symbol); EXPORT_SYMBOL_GPL (symbol); ~~~ 宏定义, 用来输出一个符号给内核. 第 2 种形式输出没有版本信息, 第 3 种限制输出给 GPL 许可的模块. ~~~ MODULE_AUTHOR(author); MODULE_DESCRIPTION(description); MODULE_VERSION(version_string); MODULE_DEVICE_TABLE(table_info); MODULE_ALIAS(alternate_name); ~~~ 放置文档在目标文件的模块中. ~~~ module_init(init_function); module_exit(exit_function); ~~~ 宏定义, 声明一个模块的初始化和清理函数. ~~~ #include <linux/moduleparam.h> module_param(variable, type, perm); ~~~ 宏定义, 创建模块参数, 可以被用户在模块加载时调整( 或者在启动时间, 对于内嵌代码). 类型可以是 bool, charp, int, invbool, short, ushort, uint, ulong, 或者 intarray. ~~~ #include <linux/kernel.h> int printk(const char * fmt, ...); ~~~ 内核代码的 printf 类似物.
';