android之init.rc文件浅析

1.  init.rc文件结构
文件位置:
init.c  : /system/core/init
init.rc  : /system/core/rootdir

首先init.rc文件是以模块为单位的,每个模块里的内容都是一起执行的,模块分为3种类型:on 、service import。
我们可以看下init.rc文件是怎么写的:
1. import
  1. import /init.usb.rc
  2. import /init.${ro.hardware}.rc
  3. import /init.trace.rc
复制代码
上面的内容很容易懂,就是导入其他的.rc文件,所以当你在android源码里添加了产品并要添加开机启动项时,就可以往这里添加。


2. on
一般on类型都是做一些chown(为文件指定用户或组) 、mkdir(新建) 、write(写入) 、export(导出) 、symlink(替身)等简单的shell指令
而且init.rc本身带了些注释,比较好懂。
  1. on post-fs-data
  2.      # We chown/chmod /data again so because mount is run as root + defaults
  3.      chown system system /data
  4.      chmod 0771 /data
复制代码
3. service
service类型的模块表示一个可执行程序,例如:
  1. service bootanim /system/bin/bootanimation
  2.       class main
  3.       user graphics
  4.       group graphics
  5.       disabled
  6.       oneshot
复制代码
bootanim为模块名
/system/bin/bootanimation为可执行文件的路径
class、user、group、onrestart这些关键字所对应的行是用来描述service一些特点。,不同的service有着不同的特点。

init.rc的结构大概就如此,那么这个init.rc是如何运行起来的呢?这个就要看init.c文件了
首先我们知道每个on模块都有自己的名字,如上边post-fs-data。然后你可以在init.c里发现这样一句:

action_for_each_trigger("post-fs-data", action_add_queue_tail);

这就把 ” on  post-fs-data“开始的这样一个section里的所有命令加入到一个执行队列,在未来的某个时候会顺序执行队列里的命令,所以调用action_for_each_trigger()的先后决定了命令执行的先后。
那这个service什么时候被执行呢?
在某个on模块的指令里会存在 “class_start” ,例如:
  1. class_start core
  2. class_start main

  3. on nonencrypted
  4. class_start late_start
复制代码
当执行到这里是service模块就会被调用。

最后关于init.c就不分析了,有兴趣的朋友应该可以通过函数名和注释很好的理解里面的内容是做些什么的。



转载自:http://forum.cubietech.com/forum.php?mod=viewthread&tid=1118&extra=page%3D1

你可能感兴趣的:(android之init.rc文件浅析)