第三章 深入理解 init
3.1 概述
init 是一个进程,它是 Linux 系统中用户空间的第一个进程,所以 init 也是 Android 系统中用户空间的第一个进程,所以它的进程号是 1。init 的两个比较重要的职责:
- init 进程负责创建系统中的几个关键进程,尤其是下一章要介绍的 zygote,它更是 Java 世界的开创者。
- Android 系统有很多属性,于是 init 就提供了一个 property service (属性服务)来管理它们。
下面主要分析 init 的两个方面:
- init 如何创建 zygote。
- init 的属性服务是如何工作的。
3.2 init 分析
init 进程的入口函数是main。
init 把动作执行的时间分为四个阶段:early-init、init、early-boot、boot。
init 关注来自四个方面的事情:
- device_fd 用于监听来自内核的 Uevent 事件。
- property_set_fd 用于监听来自属性服务器的事件。
- signal_recv_fd 由 socketpair 创建,它的事件来自另外一个 socket。
- 如果 keychord 设备初始化成功,则 init 也会关注来自这个设备的事件。
Boot chart 是一个小工具,它能对系统的性能进行分析,并生成系统启动过程的图表,以提供一些有价值的信息,而这些信息最大的用处就是帮助提升系统的启动速度。
init 的工作流程精简为一下四点:
- 解析两个配置文件,下面将分析其中对 init.rc 文件的解析。
- 执行各个阶段的动作,创建 zygote 的工作就是在其中的某个阶段完成的。
- 调用 property_init 初始化属性相关的资源,并且通过 property_start_service 启动属性服务。
- init 进入一个无限循环,并且等待一些事情的发生。重点关注 init 如何处理来自 socket 和来自属性
服务器的相关事情。
3.2.1 解析配置文件
在 init 中会解析两个配置文件,其中一个是系统配置文件 init.rc,另外一个是与硬件平台相关的配置文件。对这两个配置文件进行解析,调用的是同一个 parse_config_file 函数。
从整体来说,parse_config 首先会找到配置文件的一个 section,然后针对不同的 section 使用不同的解析函数来解析。
1、关键字定义
keywords.h 这个文件定义了 init 中使用的关键字。主要做了两件事情:
- 第一次包含 keywords.h 时,它声明了