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

来源:互联网 发布:股票交易算法 编辑:程序博客网 时间:2024/06/18 07:02
转载地址:http://blog.csdn.net/qing_ping/article/details/17354725

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

[cpp] view plain copy
print?
  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函数,作用是驱动模型子系统的初始化,对于内核驱动工程师来说比较重要,详解如下:
[cpp] view plain copy
print?
  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的编写有关。

 

 

 

阅读全文
0 0
原创粉丝点击