linux moudle并不仅仅用于支持驱动的加载和卸载。
模块代码有两种运行方式,一是静态编译连接进内核,在系统启动过程中进行初始化;
一是编译成可动态加载的module,通过insmod动态加载重定位到内核。
这两种方式可以在Makefile中通过obj -y 或 obj -m 选项选择。
一旦可动态加载的模块目标(.ko)被加载重定位到内核,其作用域和静态链接的代码是完全等价的。
这种运行方式有如下优点:
1. 可根据系统需要动态加载模块,以扩充内核功能。不需要时将其卸载,以释放内存空间。
2. 当需要修改内核功能时,只需编译相应模块,而不必重新编译整个内核。
因为这样的优点,大部分模块被编译成可动态加载的模块。但有些模块必须要编译到内核,随内核一起运行。
#ifndef MODULE
// 省略
#define module_init(x) __initcall(x);
// 省略
#else
#define module_init(initfn) \
int init_module(void) __attribute__((alias(#initfn)));
// 省略
#endif
MODULE 是由Makefile控制的。上面部分用于将模块静态编译连接进内核,下面部分用于编译可动态加载的模块。
代码梳理:
module_init机制的理解
相关文章:
linux 中module_init()加载顺序