[RK3288][Android6.0] 调试笔记 --- 系统第一次开机进入Recovery模式原因
2016-12-05 13:29
519 查看
Platform: ROCKCHIP
OS: Android 6.0
Kernel: 3.10.92
描述:
当系统全部download开机后,会默认进入Recovery模式,这个其实是misc分区里的内容在作怪.
misc分区:
misc.img是RK原始就提供而不是自己编译生成的,其实misc里内容就两行,用UE可查看:
Uboot log:
#Boot ver: 2016-11-29#2.30
empty serial no.
normal boot.
checkKey
vbus = 1
read logo on state from dts [1]
pll_src = 0, dclk_hz = 138700000, dclk_div = 2
edp pll locked
Aux Transaction fail!
link training success.
unable to config video
got recovery cmd from misc. //从它入手!
load fdt from resouce.
Secure Boot state: 0
Uboot 流程:
board_late_init -> rk32xx.c
board_fbt_preboot -> fastboot.c
rkloader_run_misc_cmd ->
get_disk_partition -> //获取misc分区的ptn, MISC_NAME是"misc"
StorageReadLba -> //这里正是读取misc分区有内容的地方
do_bootrk //如果有boot-recovery的命令,那么开机进入recovery模式. 第一此会成立,开机进入recovery后misc cmd会被清掉.
Recovery流程:
main -> recovery.cpp
get_args ->
get_bootloader_message -> bootloader.cpp
volume_for_path //获取misc分区
get_bootloader_message_block_rk29 //和uboot一样读取misc里的内容
//不过这里主要获取的是--wipe_all 这条命令,接着就会做wipe data/cache的动作.
finish_recovery -> //等全部正常完成后,会去清除misc分区里的内容,否则会一直进入recovery模式.
set_bootloader_message //清除动作.
这样的设计使得每次download后就不用再去清data/cache了,比较方便.
OS: Android 6.0
Kernel: 3.10.92
描述:
当系统全部download开机后,会默认进入Recovery模式,这个其实是misc分区里的内容在作怪.
misc分区:
misc.img是RK原始就提供而不是自己编译生成的,其实misc里内容就两行,用UE可查看:
Uboot log:
#Boot ver: 2016-11-29#2.30
empty serial no.
normal boot.
checkKey
vbus = 1
read logo on state from dts [1]
pll_src = 0, dclk_hz = 138700000, dclk_div = 2
edp pll locked
Aux Transaction fail!
link training success.
unable to config video
got recovery cmd from misc. //从它入手!
load fdt from resouce.
Secure Boot state: 0
Uboot 流程:
board_late_init -> rk32xx.c
board_fbt_preboot -> fastboot.c
rkloader_run_misc_cmd ->
get_disk_partition -> //获取misc分区的ptn, MISC_NAME是"misc"
StorageReadLba -> //这里正是读取misc分区有内容的地方
do_bootrk //如果有boot-recovery的命令,那么开机进入recovery模式. 第一此会成立,开机进入recovery后misc cmd会被清掉.
Recovery流程:
main -> recovery.cpp
get_args ->
get_bootloader_message -> bootloader.cpp
volume_for_path //获取misc分区
get_bootloader_message_block_rk29 //和uboot一样读取misc里的内容
//不过这里主要获取的是--wipe_all 这条命令,接着就会做wipe data/cache的动作.
finish_recovery -> //等全部正常完成后,会去清除misc分区里的内容,否则会一直进入recovery模式.
set_bootloader_message //清除动作.
这样的设计使得每次download后就不用再去清data/cache了,比较方便.
相关文章推荐
- [RK3288][Android6.0] 调试笔记 --- 系统第一次开机进入Recovery模式原因【转】
- [RK3288][Android6.0] 调试笔记 --- 修改boot.img后进入Recovery模式问题
- [RK3288][Android6.0] 调试笔记 --- Recovery模式下显示旋转180度
- [RK3288][Android6.0] 调试笔记 --- 开机动画画面偏移
- [RK3288][Android6.0] 调试笔记 --- 关闭音频播放停止后进入Standby功能
- [RK3288][Android6.0] 调试笔记 --- 系统识别不同硬件版本方法
- [RK3288][Android6.0] 调试笔记 --- 开机后台抓取kernel log
- [RK3288][Android6.0] 调试笔记 --- 开机Uart log丢失不完整
- [RK3288][Android6.0] 调试笔记 --- 系统识别不同硬件版本方法【转】
- [RK3288][Android6.0] 调试笔记 --- Recovery log重定向
- [RK3288][Android6.0] 调试笔记 --- 替换系统签名
- [RK3288][Android6.0] 调试笔记 --- 无法安装需系统权限的apk问题
- [RK3288][Android6.0] 调试笔记 --- 开机设置默认出厂时间方法
- [RK3288][Android6.0] 调试笔记 --- 移除uboot和kernel开机logo
- [RK3288][Android6.0] 移植笔记 --- RK818配置不正确导致无法开机调试
- [RK3288][Android6.0] 调试笔记 --- 开机语言默认为简体中文
- [RK3288][Android6.0] 调试笔记 --- 下载进入MSC设备
- [RK3288][Android6.0] 调试笔记 --- 开机动画时间的确定
- [RK3288][Android6.0] 调试笔记 --- 系统Dump Callstack方法
- [RK3288][Android6.0] 调试笔记 --- 开机默认选择24小时制时间格式