内核初始化优化宏(__init, __devinit)

原帖:http://blog.chinaunix.net/uid-25871104-id-2854544.html

在内核里经常可以看到__init, __devinit这样的语句,这都是在init.h中定义的宏,gcc在编译时会将被修饰的内容放到这些宏所代表的section。

其典型的定义如下:
  1. #define __init        __section(.init.text) __cold notrace
  2. #define __initdata    __section(.init.data)
  3. #define __initconst    __section(.init.rodata)
  4. #define __exitdata    __section(.exit.data)
  5. #define __exit_call    __used __section(.exitcall.exit)
其典型用法如下:
  1. static int __init xxx_drv_init(void)
  2. {
  3.      return pci_register_driver(&xxx_driver);
  4. }
根据上面的定义与用法,xxx_drv_init()函数将会被link到.init.text段。
之所以加入这样的宏,原因有2:
1,一部分内核初始化机制依赖与它。如kernel将初始化要执行的init函数,分为7个级别,core_initcall, postcore_initcall, arch_initcall, subsys_initcall, fs_iitcall, device_initcall, late_initcall。这7个级别优先级递减,即先执行core_initcall, 最后执行late_initcall。通过使用文中提到的宏,gcc会将初始化代码按下面的结构安排:
在内核初始化时,从__initcall_start到__initcall_end之间的initcall被一次执行。
2,提高系统效率
初始化代码的特点是,在系统启动时运行,且一旦运行后马上推出内存,不再占用内存。

================================================================================
常用的宏:
  • __init,标记内核启动时所用的初始化代码,内核启动完成后就不再使用。其所修饰的内容被放到.init.text section中。
  • __exit,标记模块退出代码,对非模块无效
  • __initdata,标记内核启动时所用的初始化数据结构,内核启动完成后不再使用。其所修饰的内容被放到.init.data section中。
  • __devinit,标记设备初始化所用的代码
  • __devinitdata,标记设备初始化所用的数据结构
  • __devexit,标记设备移除时所用的代码
  • xxx_initcall,7个级别的初始化函数
  • ==================================================================================
    driver中的使用:
    • module_init, module_exit函数所调用的函数,需要分别用__init和__exit来标记
    • pci_driver数据结构不需要标记
    • probe和remove函数用__devinit和__devexit来标记
    • 如果remove使用__devexit标记,则在pci_drvier结构中要用__devexit_p(remove)来引用remove函数
    • 如果不确定需不需要添加宏,则不要添加
  • __devinit,标记设备初始化所用的代码
  • __devinitdata,标记设备初始化所用的数据结构
  • __devexit,标记设备移除时所用的代码
  • xxx_initcall,7个级别的初始化函数
==================================================================================
driver中的使用:
  • module_init, module_exit函数所调用的函数,需要分别用__init和__exit来标记
  • pci_driver数据结构不需要标记
  • probe和remove函数用__devinit和__devexit来标记
  • 如果remove使用__devexit标记,则在pci_drvier结构中要用__devexit_p(remove)来引用remove函数
  • 如果不确定需不需要添加宏,则不要添加

博客推荐文章
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值