init_module

Section: Misc. Reference Manual Pages ()
Index Return to Main Contents
 

NAME

init_module - 初始化一条可加载模块的记录.  

总览

#include <linux/module.h>

int init_module(const char *name, struct module *image);  

描述

init_module加载已被重定位的模块映象到内核空间,并运行模块的初始化函数. 模块映象以module结构开始,紧跟着代码和数据,module定义如下:
       struct module                                              
       {
         unsigned long size_of_struct; /* module结构的大小 */
         struct module *next; /*指向下一个module结构 */
         const char *name; /* 模块名字 */
         unsigned long size;
         long usecount; /* 使用计数 */
         unsigned long flags; /* 模块当前状态标志 */
         unsigned int nsyms;
         unsigned int ndeps; /* 正使用模块的模块个数 */
         struct module_symbol *syms;
         struct module_ref *deps;
         struct module_ref *refs;
         int (*init)(void); /* 模块的初始化函数指针 */
         void (*cleanup)(void); /*模块的清除函数指针 */
         const struct exception_table_entry *ex_table_start;
         const struct exception_table_entry *ex_table_end;
       #ifdef __alpha__
         unsigned long gp;
       #endif
       }; 除了next和refs外,所有的指针被期望指在模块体内, 该系统调用只对超级用户开放.  

返回值

成功时返回0,错误时返回 -1,errno被相应设置.  

错误

EPERM

    用户不是超级用户.
ENOENT

    name指定的模块不存在.
EINVAL
EBUSY

    模块的初始化函数失败.
EFAULT

    name或image越出了程序可访问的地址空间.

 


      雷勇 <nsinit@263.net>


 

Index

NAME
总览
描述
返回值
错误

      雷勇 <nsinit@263.net>

This document was created by man2html, using the manual pages.
Time: 13:12:16 GMT, December 24, 2015