恢复出厂设置流程
recovery.img与boot.img的对比
recovery .img和boot.img的文件结构的对比:1)recovery.img其实已经是进入了Linux系统。(2)recovery.img为了具有恢复系统的能力,比普通的boot.img目录结构中:
1、多了/res/images目录,在这个目录下的图片都是恢复时我们看到的背景画面。
2、多了/sbin/recovery二进制程序,这个就是恢复用的程序。
3、/sbin/adbd不一样,应该和恢复有关。
(3)Android系统中的初始化程序(init)和初始化配置文件(default.prop、init.trout.rc、init.rc、init.goldfish.rc、)都不一样。
这就是系统没有进入图形界面而进入了类似文本界面,并可以通过简单的组合键进行恢复的原因。
恢复出厂设置流程概括:
一. 设置模块中进行恢复出厂设置操作,系统一共做了两件事:
1. 往 /cache/recovery/command 文件中写入命令字段:reboot recovery
2. 重启系统
二. 重启系统会必须进入 recovery 模式
进入 recovery 模式的几种方式1. 通过读取 /cache 分区中文件 /cache/recovery/command 内容进入
2. 通过按键操作进入 (G1 通过同时按 HOME 和 挂断键)以上两种方式进入都需要 bootloader的支持
三. 所以恢复出厂设置,进入 recovery 模式,必须做以下几件事情:
1. bootloader 必须能从 recovery 分区中装载内核和文件系统
2. flash 必须有 cache 分区 和 recovery 分区
3. 必须编译提供 recovery.img 烧录到 recovery 分区
恢复模式流程分析完成了以上准备工作,当我们按特定的组合键或者恢复出厂设置,那么就会进入 recovery 模式:从 recovery 模式的 init.rc 文件可以看出,
它仅仅启动了几个服务 service recovery /sbin/recoveryservice adbd /sbin/adbd recovery以下是 recovery 流程分析,
主函数在文件:bootable/recovery/recovery.c int main(int argc, char **argv) ... ui_init(); //初始化ui get_args(&argc, &argv);
...void ui_init(void){ gr_init();
ev_init(); ... pthread_create(&t, NULL, progress_thread, NULL);
pthread_create(&t, NULL, input_thread, NULL);}
recovery 模式有简单的交互式界面,它是通过 ui_init(),ev_init()等一些列操作,完成字符ui界面和按键事件等初始化。input_thread 线程里面处理按键事件。
函数 get_args 会读取 /cache/recovery/command 文件,并根据命令字段进行相应操作,
所以它会擦除 data 和 cache 分区:
erase_root(/"DATA:/")
erase_root(/"CACHE:/")
分区擦除后,系统重启,然后进入正常开机流程,重新使用 system 分区的内容完成开机初始化。
Recovery Case
-
用户选择“恢复出厂设置”
-
设置系统将"--wipe_data"命令写入/cache/recovery/command
-
给内核发restart 命令,系统重启,bootloader并进入recover模式(/sbin/recovery)
-
get_args()将"boot-recovery"和"--wipe_data"写入BCB
-
erase_root()格式化(擦除)DATA分区
-
erase_root()格式化(擦除)CACHE分区
-
finish_recovery()擦除BCB
-
重启系统