Linux内核模块加载函数一般以_ _init 标识声明,典型的模块加载函数的形式如代码 ---------insmod hello.ko时被调用。
清单4.2所示。
代码清单4.2 内核模块加载函数
1 static int _ _init initialization_function(void)
2 {
3 /* 初始化代码 */
4 }
5 module_init(initialization_function);
模块加载函数必须以“module_init(函数名)”的形式被指定。它返回整型值,若初始
化成功,应返回0。而在初始化失败时,应该返回错误编码。在Linux内核里,错误编码
是一个负值,在<linux/errno.h>中定义,包含-ENODEV、-ENOMEM之类的符号值。返
回相应的错误编码是种非常好的习惯,因为只有这样,用户程序才可以利用perror等方
法把它们转换成有意义的错误信息字符串。
在Linux 2.6内核中,可以使用request_module(const char *fmt, …)函数加载内核
模块,驱动开发人员可以通过调用
request_module(module_name);
或
request_module("char-major-%d-%d", MAJOR(dev), MINOR(dev));
来加载其他内核模块。
在Linux内核中,所有标识为_ _init 的函数在连接的时候都放在.init.text
清单4.2所示。
代码清单4.2 内核模块加载函数
1 static int _ _init initialization_function(void)
2 {
3 /* 初始化代码 */
4 }
5 module_init(initialization_function);
模块加载函数必须以“module_init(函数名)”的形式被指定。它返回整型值,若初始
化成功,应返回0。而在初始化失败时,应该返回错误编码。在Linux内核里,错误编码
是一个负值,在<linux/errno.h>中定义,包含-ENODEV、-ENOMEM之类的符号值。返
回相应的错误编码是种非常好的习惯,因为只有这样,用户程序才可以利用perror等方
法把它们转换成有意义的错误信息字符串。
在Linux 2.6内核中,可以使用request_module(const char *fmt, …)函数加载内核
模块,驱动开发人员可以通过调用
request_module(module_name);
或
request_module("char-major-%d-%d", MAJOR(dev), MINOR(dev));
来加载其他内核模块。
在Linux内核中,所有标识为_ _init 的函数在连接的时候都放在.init.text