linux 3.6 启动源码分析(六) do_basic_setup

转载地址:http://blog.csdn.net/qing_ping/article/details/17354725

在内核init线程中调用了do_basic_setup,这个函数也做了很多内核和驱动的初始化工作

  1. /*好了, 设备现在已经初始化完成。 但是还没有一个设备被初始化过, 
  2.  但是 CPU 的子系统已经启动并运行, 
  3.  且内存和处理器管理系统已经在工作了。 
  4.  现在我们终于可以开始做一些实际的工作了.. 
  5.  */  
  6. static void __init do_basic_setup(void)  
  7. {  
  8.     cpuset_init_smp();//针对SMP系统,初始化内核control group的cpuset子系统。如果非SMP,此函数为空。  
  9.     /*创建一个单线程工作队列khelper。运行的系统中只有一个,主要作用是指定用户空间的程序路径和环境变量, 最终运行指定的user space的程序,属于关键线程,不能关闭*/  
  10.     usermodehelper_init();  
  11.       
  12.     shmem_init();  
  13.     driver_init();//初始化驱动模型中的各子系统,可见的现象是在/sys中出现的目录和文件  
  14.     init_irq_proc();//在proc文件系统中创建irq目录,并在其中初始化系统中所有中断对应的目录。  
  15.     do_ctors();//调用链接到内核中的所有构造函数,也就是链接进.ctors段中的所有函数。  
  16.     usermodehelper_enable();  
  17.     do_initcalls();//调用所有编译内核的驱动模块中的初始化函数。  
  18. }  
/*好了, 设备现在已经初始化完成。 但是还没有一个设备被初始化过,
 但是 CPU 的子系统已经启动并运行,
 且内存和处理器管理系统已经在工作了。
 现在我们终于可以开始做一些实际的工作了..
 */
static void __init do_basic_setup(void)
{
    cpuset_init_smp();//针对SMP系统,初始化内核control group的cpuset子系统。如果非SMP,此函数为空。
    /*创建一个单线程工作队列khelper。运行的系统中只有一个,主要作用是指定用户空间的程序路径和环境变量, 最终运行指定的user space的程序,属于关键线程,不能关闭*/
    usermodehelper_init();

    shmem_init();
    driver_init();//初始化驱动模型中的各子系统,可见的现象是在/sys中出现的目录和文件
    init_irq_proc();//在proc文件系统中创建irq目录,并在其中初始化系统中所有中断对应的目录。
    do_ctors();//调用链接到内核中的所有构造函数,也就是链接进.ctors段中的所有函数。
    usermodehelper_enable();
    do_initcalls();//调用所有编译内核的驱动模块中的初始化函数。
}

上面的函数调用了driver_init函数,作用是驱动模型子系统的初始化,对于内核驱动工程师来说比较重要,详解如下:
  1. void __init driver_init(void)  
  2. {  
  3.     /* These are the core pieces */  
  4.     devtmpfs_init();//初始化devtmpfs文件系统,驱动核心设备将在这个文件系统中添加它们的设备节点。  
  5.     /*初始化驱动模型中的部分子系统和kobject: 
  6.     devices 
  7.     dev 
  8.     dev/block 
  9.     dev/char 
  10.     */  
  11.     devices_init();  
  12.     buses_init();//初始化驱动模型中的bus子系统  
  13.     classes_init();//1.初始化驱动模型中的class子系统  
  14.     firmware_init();//1.初始化驱动模型中的firmware子系统  
  15.     hypervisor_init();//1.初始化驱动模型中的hypervisor子系统  
  16.   
  17.     /* These are also core pieces, but must come after the 
  18.      * core core pieces.      
  19.      这些也是核心部件, 但是必须在以上核心中的核心部件之后调用。 
  20.      */  
  21.     platform_bus_init();//1.初始化驱动模型中的bus/platform子系统  
  22.     cpu_dev_init();//1.初始化驱动模型中的devices/system/cpu子系统  
  23.     memory_dev_init();//初始化驱动模型中的devices/system/memory子系统  
  24. }  
void __init driver_init(void)
{
    /* These are the core pieces */
    devtmpfs_init();//初始化devtmpfs文件系统,驱动核心设备将在这个文件系统中添加它们的设备节点。
    /*初始化驱动模型中的部分子系统和kobject:
    devices
    dev
    dev/block
    dev/char
    */
    devices_init();
    buses_init();//初始化驱动模型中的bus子系统
    classes_init();//1.初始化驱动模型中的class子系统
    firmware_init();//1.初始化驱动模型中的firmware子系统
    hypervisor_init();//1.初始化驱动模型中的hypervisor子系统

    /* These are also core pieces, but must come after the
     * core core pieces.     
     这些也是核心部件, 但是必须在以上核心中的核心部件之后调用。
     */
    platform_bus_init();//1.初始化驱动模型中的bus/platform子系统
    cpu_dev_init();//1.初始化驱动模型中的devices/system/cpu子系统
    memory_dev_init();//初始化驱动模型中的devices/system/memory子系统
}


 而另外一个很主要的函数do_initcalls()调用所有编译内核的驱动模块中的初始化函数。其中按照各个内核模块初始化函数所自定义的启动级别(1~7),按顺序调用器初始化函数。对于同一级别的初始化函数,安装编译是链接的顺序调用,也就是和内核Makefile的编写有关。

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值