Androidkernel启动后执行Init初始化,代码在system/core/init中。
- 创建/dev /proc/sys 目录,创建/dev/pts目录(伪终端)和/dev/socket,并分别mount
- 创建空设备节点,创建kmsg设备节点,初始化log
- 解析init.rc
- 读取保存在/proc/cmdline中的kernel启动参数:
- qemu
- androidboot.console
- androidboot.mode
- factory
- factory2
- androidboot.serialno
- androidboot.baseband
- androidboot.carrier
- androidboot.bootloader
- androidboot.hardware
- 读取hardware信息,如果cmdline中没有指出则到/proc/cupinfo中找
- 解析/init.“hardware信息”.rc
- early-init
- 设备初始化,coldboot/sys/class /sys/block /sys/devices,将这些目录下的uevent文件找出,并使kernel重新生成那些在init的设备管理器开始前的设备添加事件。
- 初始化property,从/default.prop中读取property。
- 如果ro.debuggable为1,则初始化组合键(keychord)监听
- 打开console,如果cmdline中没有指定console则打开默认的/dev/console
- 读取/initlogo.rle,是一张565 rle 压缩的位图,如果成功则在/dev/fb0显示Logo,如果失败则将/dev/tty0设为TEXT模式并打开/dev/tty0,输出文本的ANDROID字样。
- 判断cmdline 中的参数:
- 如果 bootmode为
- factory,设置ro.factorytest值为1
- factory2,设置ro.factorytest值为2
- 其他的设ro.factorytest值为0
- 如果有serialno则设置ro.serialno,否则为""
- 如果有bootmod则设置ro.bootmod,否则为"unknown"
- 如果有baseband则设置ro.baseband,否则为"unknown"
- 如果有carrier则设置ro.carrier,否则为"unknown"
- 如果有bootloader则设置ro.bootloader,否则为"unknown"
- 设置ro.hardware
- 设置ro.version
- 执行所有触发标识为init的action
- 开始property服务,读取一些property文件,这一动作必须在前面那些ro.foo设置后做,以便/data/local.prop不能干预到他们。
- /system/build.prop
- /system/default.prop
- /data/local.prop
- 在读取默认的property后读取presistent propertie,在/data/property中
- 为sigchld handler创建信号机制
- 确认所有初始化工作完成
- device_fd(device init 完成)
- property_set_fd(property server start 完成)
- signal_recv_fd (信号机制建立)
- 执行所有触发标识为early-boot的action
- 执行所有触发标识为boot的action
- 基于当前property状态,执行所有触发标识为property的action
- 注册轮询事件:
- device_fd
- property_set_fd
-signal_recv_fd
-如果有keychord,则注册keychord_fd
- 如果支持BOOTCHART,则初始化BOOTCHART
- 进入主进程循环:
- 重置轮询事件的接受状态,revents为0
- 查询action队列
- 重启需要重启的进程
- 轮询注册的事件
- 如果signal_recv_fd的revents为POLLIN,则得到一个信号,获取并处理
- 如果device_fd的revents为POLLIN,调用handle_device_fd
- 如果property_fd的revents为POLLIN,调用handle_property_set_fd
- 如果keychord_fd的revents为POLLIN,调用handle_keychord