在gingerbread/bootable/recovery/recovery.c最下面有个main(),这是recovery应用的主入 口,当编译recovery的时候,会生成一个名为recovery的可执行文件,我这边是放在out/目录下recovery/文件系统的/sbin目 录下,调用recovery可执行文件时会传入参数,这些参数就是main函数的参数,如下
02 | main( int argc, char **argv) |
05 | time_t start = time (NULL); |
10 | INFO( ">>>>> Enter recovery <<<<<\n" ); |
argc是参数个数,argv是每个参数指针
从这里开始了recovery…
2、获取commond
2 | get_args( int *argc, char ***argv) { |
3 | // INFO("Enter get_args\n"); |
4 | struct bootloader_message boot; |
5 | memset (&boot, 0, sizeof (boot)); |
如果命令行有recovery命令,优先执行命令行的recovery命令; 否则,往下查找misc分区中的命令、/cache/recovery/command文件中的命
3、获取默认升级固件路径和名称
int property_get(const char *key, char *value, const char *default_value);
包括U盘、SD卡和Flash升级
4、解析命令
int getopt_long(int, char * const *, const char *, const struct option *, int *);
如 case ‘s’: send_intent = optarg; break;
optarg是取命令中等号后面字符串
注册一些命令,register_update_commands函数是注册在update-script和recovery-script使用的升级命令
初始化一个变量,int status = INSTALL_SUCCESS;这个变量是用来标识升级是否成功,在清除misc分区命令时候作为一个判断依据
5、升级、格式化、还原
接下来,有三种需求,一是factorytest;二是update、recover;三是wipe data
01 | if (update_image != NULL) { |
02 | status = install_update(update_image); |
04 | ui_set_background(BACKGROUND_ICON_ERROR); |
05 | if (status==-1) g_enable_item_move = false ; |
07 | } else if (recover_image != NULL){ |
08 | status = recover_backup(recover_image); |
10 | ui_set_background(BACKGROUND_ICON_ERROR); |
11 | if (status==-1) g_enable_item_move = false ; |
这部分代码是update\recover的需求,update走install_update分支,recovery走recover_backup分 支,g_enable_item_move是在recovery升级界面条目是否可移动的一个变量,false表示不能移动
02 | if ( wipe_data(wipe_flags) != 0 ) |
04 | status = INSTALL_ERROR; |
05 | ui_print( "Data wipe failed.\n" ); |
06 | // 不擦除misc中的命令,重启后再次格式化 |
07 | g_reset_blmsg = false ; |
08 | g_enable_item_move = false ; |
这部分是擦除数据,就是格式化需求,根据擦除flags记录,分别去擦除需要格式化的分区或者磁盘,如果擦除失败,g_reset_blmsg 这个变量在擦除boot时候作为判别依据,false表示不擦出,这样,misc分区的内容还是recovey,下次重启后,boot引导进入 recovery模式 prompt_and_wait()函数里面,关键部分
本文标签:
代码androidrecovery
发表评论