免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3091 | 回复: 4

initcall 调用顺序以及依赖问题 [复制链接]

论坛徽章:
0
发表于 2012-04-20 10:18 |显示全部楼层
我们知道在kernel中有initcall这个机制来方便我们的一些初始化的动作,有以下几种initcall

core_initcall(fn)                                 .initcall1.init
postcore_initcall(fn)                           .initcall2.init
arch_initcall(fn)                                 .initcall3.init
subsys_initcall(fn)                             .initcall4.init
fs_initcall(fn)                                    .initcall5.init
device_initcall(fn)                              .initcall6.init
late_initcall(fn)                                  .initcall7.init


请问,在kernel初始化的时候他们的顺序是什么,那在什么情况下应该使用core_initcall, 而又在什么情况下使用arch_initcall呢?

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
发表于 2012-04-20 10:37 |显示全部楼层
本帖最后由 embeddedlwp 于 2012-04-20 11:14 编辑

回复 1# cuibixiong_cu

在vmlinux.lds.S文件中有:
  1.   71  __initcall_start = .;
  2.   72  .initcall.init : {
  3.   73        *(.initcall1.init)
  4.   74        *(.initcall2.init)
  5.   75        *(.initcall3.init)
  6.   76        *(.initcall4.init)
  7.   77        *(.initcall5.init)
  8.   78        *(.initcall6.init)
  9.   79        *(.initcall7.init)
  10.   80  }
  11.   81  __initcall_end = .;
复制代码
start_kenrel->rest_init->kernel_thread->init->do_basic_setup->do_initcalls:
  1. 530static void __init do_initcalls(void)
  2. 531{
  3. 532        initcall_t *call;
  4. 533        int count = preempt_count();
  5. 534
  6. 535        for (call = __initcall_start; call < __initcall_end; call++) {
  7. 536                char *msg;
  8. 537
  9. 538                if (initcall_debug) {
  10. 539                        printk(KERN_DEBUG "Calling initcall 0x%p", *call);
  11. 540                        print_fn_descriptor_symbol(": %s()", (unsigned long) *call);
  12. 541                        printk("\n");
  13. 542                }
  14. 543
  15. 544                (*call)();
  16. 545
  17. 546                msg = NULL;
  18. 547                if (preempt_count() != count) {
  19. 548                        msg = "preemption imbalance";
  20. 549                        preempt_count() = count;
  21. 550                }
  22. 551                if (irqs_disabled()) {
  23. 552                        msg = "disabled interrupts";
  24. 553                        local_irq_enable();
  25. 554                }
  26. 555                if (msg) {
  27. 556                        printk("error in initcall at 0x%p: "
  28. 557                                "returned with %s\n", *call, msg);
  29. 558                }
  30. 559        }
  31. 560
  32. 561        /* Make sure there is no pending stuff from the initcall sequence */
  33. 562        flush_scheduled_work();
  34. 563}
复制代码

论坛徽章:
0
发表于 2012-04-20 10:42 |显示全部楼层
回复 2# embeddedlwp


    1.那什么时候改用core_initcall,什么时候改用arch_init呢?是如何区分的呢?
   2.vmlinux.lds中只是定义了initcall所在的section,应该是并没有定义其调用顺序吧?

论坛徽章:
0
发表于 2012-04-20 11:07 |显示全部楼层
本帖最后由 xxw19840406 于 2012-04-20 11:49 编辑

这个嘛   重要的就赋于较高的优先级,不太重要的优先级低点
core_initcall(fn)                                 .initcall1.init
postcore_initcall(fn)                           .initcall2.init
arch_initcall(fn)                                 .initcall3.init
subsys_initcall(fn)                             .initcall4.init
fs_initcall(fn)                                    .initcall5.init
device_initcall(fn)                              .initcall6.init
late_initcall(fn)                                  .initcall7.init

从这些名字也能看出一些,就是如果你的代码是arch级的就用arch_initcall(像machine级的初始化)
是subsys级的就用subsys_initcall(像USB、SD、I2C等子系统初始化,总线初始化加载是放在postcore_initcall中)
是device级的就用device_initcall(比如设备驱动初始化)

反正就是如果B的初始化需要依赖A初始化完成,那边B的等级就不能高过A

其他的我也不太清楚了

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
发表于 2012-04-20 11:16 |显示全部楼层
回复 3# cuibixiong_cu


从上边的do_initcalls函数的for循环来看,应该是从initcall1~initcall7依次调用的吧!


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP