分享

init.rc

 吴家小院 2014-12-10

一、init.rc文件结构介绍

init.rc文件基本组成单位是section, section分为三种类型,分别由三个关键字(所谓关键字即每一行的第一列)来区分,这三个关键字是onserviceimport

 

on类型的section表示一系列命令的组合, 例如:

 

on init

   export PATH /sbin:/system/sbin:/system/bin

   export ANDROID_ROOT /system

   export ANDROID_DATA /data

 

这样一个section包含了三个export命令,命令的执行是以section为单位的,所以这三个命令是一起执行的,不会单独执行, 那什么时候执行呢? 这是由init.cmain()所决定的,main()里在某个时间会调用

action_for_each_trigger("init", action_add_queue_tail);

这就把on init开始的这样一个section里的所有命令加入到一个执行队列,在未来的某个时候会顺序执行队列里的命令,所以调用action_for_each_trigger的先后决定了命令执行的先后。

 

 

service类型的section表示一个可执行程序,例如:

 

service surfaceflinger /system/bin/surfaceflinger

   class main

   user system

   group graphics drmrpc

   onrestart restart zygote

 

surfaceflinger作为一个名字标识了这个service, /system/bin/surfaceflinger表示可执行文件的位置, classusergrouponrestart这些关键字所对应的行都被称为options, options是用来描述的service一些特点,不同的service有着不同的options

service类型的section标识了一个service(或者说可执行程序), 那这个service什么时候被执行呢?是在class_start这个命令被执行的时候,class_start命令行总是存在于某个on类型的section中,“class_start core”这样一条命令被执行,就会启动类型为core的所有service

所以可以看出android的启动过程主要就是on类型的section被执行的过程。

 

 

import类型的section表示引入另外一个.rc文件,例如:

      

import init.test.rc

 

相当包含另外一些section, 在解析完init.rc文件后继续会调用init_parse_config_file来解析引入的.rc文件。


二、init.rc的执行顺序






1. 所有的action运行于service之前


2.  下面为各个section的执行顺序,英文编号的section是系统内建的(写死在init.c中的命令)


1) early-init


    a) wait_for_coldboot_done


    b) property_init


    c) keychord_int


    d) console_init


    e) set_init_properties


2) init


3) early-fs


4) fs


5) post-fs


    f) property_service_init


    g) signal_init


    h) check_startup


6) early-boot


7) boot


8) service




3. 同一个section内的执行顺诉根据脚本中的先后位置决定


4. init.rc 和 init.xxx.rc的执行顺序,两个脚本文件可以包含相同的sction,但是对每一个section,都是先执行完init.rc,再去执行init.xxx.rc



参照system/core/init/init.c代码,加少许打印信息,即可得到命令和服务的执行顺寻

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多