msm8953+android8.1启动异常进入recovery模式_需要格式化data分区恢复启动


1.    问题现象和背景
 msm8953+android8.1启动异常进入recovery模式_需要格式化data分区恢复启动

"Can't load Android system. Your data may be corrupt. "
    "If you continue to get this message, you may need to "
    "perform a factory data reset and erase all user data "
    "stored on this device.",

在测试验证填满空间后系统是否能够正常启动,发现了此问题,操作步骤:
(1)    烧录系统后,恢复一次出厂设置。
(2)    用命令adb shell dd if=/dev/zero of=/mnt/sdcard/bigfile占满空间。
(3)    重启设备。

重启设备无法正常启动后,再开机就进入此界面,重新刷机也不行(奇怪),当然在QFIL刷机时如果选择Erase All Before Download刷系统是可以正常启动的,但是我们没有格式化所有分区,因为这样会丢失一些重要数据,比如模块的SN号、蓝牙地址等信息。

2.    恢复机制
根据上图如果设备有向下按键,可以通过选择Factory data reset来恢复到正常启动,但如果没有向下按键,则需要通过修改bootable\recovery\recovery.cpp,改为默认格式化data来解决,patch如下
msm8953+android8.1启动异常进入recovery模式_需要格式化data分区恢复启动

就是改为默认执行Factory data reset对应的操作wipe_data()

msm8953+android8.1启动异常进入recovery模式_需要格式化data分区恢复启动