安卓recovery流程分析(编译、界面、图片)

目录

recovery 界面菜单

recovery 界面操作

recovery 启动流程

recovery 编译makefile

recovery 图片大小

ramdisk、boot.img、recovery.img之间的关系


authordaisy.skye的博客_CSDN博客-嵌入式,Qt,Linux领域博主

recovery 界面菜单

recovery 界面显示

android recoveryuse

路径

bootable/recovery/device.cpp

背景设置

void ScreenRecoveryUI::draw_background_locked() {

 gr_color(0, 0, 0, 255); 

}

第一个参数 0:表示红色分量的强度,这里是最小值,表示没有红色。

第二个参数 0:表示绿色分量的强度,这里是最小值,表示没有绿色。

第三个参数 0:表示蓝色分量的强度,这里是最小值,表示没有蓝色。

第四个参数 255:表示透明度或不透明度,这里是最大值,表示完全不透明。

因此,gr_color(0, 0, 0, 255) 表示的是一个完全不透明的黑色。

如果要设置绿色不透明背景,修改参数为gr_color(0, 255, 0, 255)

路径

bootable/recovery/screen_ui.cpp

#include "device.h"
static const char* MENU_ITEMS[] = {"Reboot system now","Reboot to bootloader","Apply update from ADB","Apply update from SD card","Wipe data/factory reset",
#ifndef AB_OTA_UPDATER"Wipe cache partition",
#endif  // !AB_OTA_UPDATER"Mount /system","View recovery logs","Run graphics test","Power off",NULL,
};static const Device::BuiltinAction MENU_ACTIONS[] = {
    Device::REBOOT,
    Device::REBOOT_BOOTLOADER,
    Device::APPLY_ADB_SIDELOAD,
    Device::APPLY_SDCARD,
    Device::WIPE_DATA,
#ifndef AB_OTA_UPDATER
    Device::WIPE_CACHE,
#endif  // !AB_OTA_UPDATER
    Device::MOUNT_SYSTEM,
    Device::VIEW_RECOVERY_LOGS,
    Device::RUN_GRAPHICS_TEST,
    Device::SHUTDOWN,
};static_assert(sizeof(MENU_ITEMS) / sizeof(MENU_ITEMS[0]) ==sizeof(MENU_ACTIONS) / sizeof(MENU_ACTIONS[0]) + 1,"MENU_ITEMS and MENU_ACTIONS should have the same length, ""except for the extra NULL entry in MENU_ITEMS.");const char* const* Device::GetMenuItems() {return MENU_ITEMS;
}

这段代码定义了两个数组:MENU_ITEMS和MENU_ACTIONS。这两个数组用于存储菜单项和对应的操作。

MENU_ITEMS是一个字符串数组,包含了一系列菜单项的名称。每个菜单项都是一个字符串常量。

MENU_ACTIONS是一个Device::BuiltinAction类型的数组,用于存储与每个菜单项对应的操作。Device::BuiltinAction是一个枚举类型,表示设备的内置操作,如重启、应用更新、擦除数据等。

在MENU_ITEMS数组的末尾,有一个NULL指针,表示数组的结束。

代码中的GetMenuItems()函数返回了MENU_ITEMS数组的地址,即菜单项的名称数组的地址。

最后,代码使用了static_assert语句来确保MENU_ITEMS和MENU_ACTIONS数组的长度相同,除了MENU_ITEMS数组中的额外的NULL条目。如果长度不同,编译时将会报错。

recovery 界面操作

代码中的GetMenuItems()函数返回了MENU_ITEMS数组的地址,即菜单项的名称数组的地址。具体经过switch和case进行具体的操作

// Return REBOOT, SHUTDOWN, or REBOOT_BOOTLOADER.  Returning NO_ACTION
// means to take the default, which is to reboot or shutdown depending
// on if the --shutdown_after flag was passed to recovery.
static Device::BuiltinAction
prompt_and_wait(Device* device, int status) {for (;;) {finish_recovery(NULL);switch (status) {case INSTALL_SUCCESS:case INSTALL_NONE:
                ui->SetBackground(RecoveryUI::NO_COMMAND);break;case INSTALL_ERROR:case INSTALL_CORRUPT:
                ui->SetBackground(RecoveryUI::ERROR);break;}
        ui->SetProgressType(RecoveryUI::EMPTY);int chosen_item = get_menu_selection(nullptr, device->GetMenuItems(), 0, 0, device);// device-specific code may take some action here.  It may// return one of the core actions handled in the switch// statement below.
        Device::BuiltinAction chosen_action = device->InvokeMenuItem(chosen_item);bool should_wipe_cache = false;switch (chosen_action) {case Device::NO_ACTION:break;case Device::REBOOT:case Device::SHUTDOWN:case Device::REBOOT_BOOTLOADER:return chosen_action;case Device::WIPE_DATA:wipe_data(ui->IsTextVisible(), device);if (!ui->IsTextVisible()) return Device::NO_ACTION;break;case Device::WIPE_CACHE:wipe_cache(ui->IsTextVisible(), device);if (!ui->IsTextVisible()) return Device::NO_ACTION;break;case Device::APPLY_ADB_SIDELOAD:case Device::APPLY_SDCARD://省略代码……    break;case Device::VIEW_RECOVERY_LOGS:choose_recovery_file(device);break;case Device::RUN_GRAPHICS_TEST:run_graphics_test(device);break;case Device::MOUNT_SYSTEM:
#ifdef USE_MDTPif (is_mdtp_activated()) {
                    ui->Print("Mounting /system forbidden by MDTP.\n");}else
#endif//省略代码……    break;}}
}

这段代码定义了一个函数prompt_and_wait,该函数用于提示用户选择一个操作,并等待用户的输入。

函数的参数包括一个指向Device对象的指针device和一个整数status。

函数使用一个无限循环for (;;) {}来不断执行以下操作:

调用finish_recovery(NULL)函数,完成recovery操作的最后步骤。

根据status的值,设置recovery界面的背景和进度条的类型。

如果status的值是INSTALL_SUCCESS或INSTALL_NONE,则将背景设置为RecoveryUI::NO_COMMAND;如果status的值是INSTALL_ERROR或INSTALL_CORRUPT,则将背景设置为RecoveryUI::ERROR。

将进度条的类型设置为RecoveryUI::EMPTY,表示没有进度信息。

调用get_menu_selection函数,显示菜单并等待用户选择。该函数的参数包括一个空指针nullptr,表示不显示标题;device->GetMenuItems(),表示获取设备的菜单项;0,表示不显示菜单的起始索引;0,表示不显示菜单的结束索引;device,表示设备对象。

函数最终返回用户选择的操作,可以是Device::REBOOT、Device::SHUTDOWN或Device::REBOOT_BOOTLOADER。如果用户没有选择任何操作,则返回Device::NO_ACTION,表示采取默认操作,即根据--shutdown_after标志决定是重启还是关机。

recovery 启动流程

参考链接

Recovery启动流程(2)---UI界面【转】-腾讯云开发者社区-腾讯云

https://www.cnblogs.com/xiaolei-kaiyuan/p/5456227.html

android-ramdisk.img分析、recovery.img&boot.img执行过程

我们知道,当我们通过按键或者应用进入recovery模式,实质是kernel后加载recovery.img,kernel起来后执行的第一个进程就是init,此进程会读入init.rc启动相应的服务。在recovery模式中,启动的服务是执行recovery可执行文件,此文件是bootable/recovery/recovery.cpp文件生成,我们就从recovery.cpp文件开始分析。

从recovery.cpp main()中可知,进入recovery后会分析/cache/recovery/command文件,根据内容来设定显示的文字语言

SetLocale函数根据locale判断所用的字体是否属于阿拉伯语系,阿拉伯语的书写习惯是从右到左,如果是阿拉伯语系的话,就设置一个标志,后面根据这个标志决定从右到左显示文字或进度条。关于显示文字的语言通过代码即可查看,这里只简单的列出语言设置的几条主线,不贴出具体的代码(太多了)。

recovery 编译makefile

makefile路径

build/core/Makefile

代码

/res 对应路径

bootable/recovery/res-xhdpi

bootable/recovery/res-mdpi

build/core/Makefile

# Otherwise, use the default medium density.
recovery_densities := ldpi
endififneq (,$(wildcard $(recovery_resources_common)-$(recovery_density)))
recovery_resources_common := $(recovery_resources_common)-$(recovery_density)
else
# recovery_resources_common := $(recovery_resources_common)-xhdpi
recovery_resources_common := $(recovery_resources_common)-mdpi
endif

recovery 图片大小

路径

bootable/recovery/fonts

内容

2*22.png 打开如图用ps查看,并裁剪其中一个字符的大小是12*22像素

注意要包含空余空余

img文件

编译出来的recovery.img

ramdisk、boot.img、recovery.img之间的关系

ramdisk.img会被打包到boot.img和recovery.img中(不是同一个ramdisk.img).

ramdisk.img中比较重要的文件是"init","init.rc",其中init是system/core/init/init.c编译而来,

boot.img中ramdisk里的init.rc位于system/core/init/init.rc,

recovery.img中ramdisk里的init.rc位于bootable/recovery/etc/init.rc。

kernel加载结束以后第一个进程是执行init,init会解析init.rc文件,并起相应的服务。

由此可以知道正常开机和进入recovery模式起的进程是不同的。

感悟

        recovery这个块是自己在调试低分辨率屏幕时,kernel阶段正常显示,但是recovery界面灭有显示而排查的,后面发现主要是由于lk阶段的panel_xxxx_video.h文件初始化的command有关,但是recovery的fronts中的字符库分辨率大小确实影响了显示recovery.img的背景显示。

        另外在排查问题的过程中阅读别人的博客学习,但是很容易就忘记,所以就把优质博客记录下来一方面方便自己查阅,另一方面也是帮助大家过滤

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/89226.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TCP协议和UDP协议

TCP通信原理 TCP(Transmission Control Protocol,传输控制协议)是一种传输层协议,它主要负责点对点的数据传输TCP 主要特点是面向连接的,也就是说,在数据传输之前,它需要先建立一个连接。连接建…

uniapp实现表格冻结

效果图如下: 思路: 1.由于APP项目需要,起初想去插件市场直接找现成的,结果找了很久没找到合适的(有的不支持vue2有的不能都支持APP和小程序) 2.后来,就只能去改uni-table源码了,因…

Unity制作旋转光束

Unity制作旋转光束 大家好,我是阿赵。 这是一个在很多游戏里面可能都看到过的效果,在传送门、魔法阵、角色等脚底下往上散发出一束拉丝形状的光,然后在不停的旋转。 这次来在Unity引擎里面做一下这种效果。 一、准备材料 需要准备的素材很简…

leetCode 62.不同路径 动态规划 + 空间复杂度优化

62. 不同路径 - 力扣(LeetCode) 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” &#xf…

登录业务实现 - token登录鉴权

登录业务实现: 登录成功/失败实现 -> pinia管理用户数据及数据持久化 -> 不同登录状态的模板适配 -> 请求拦截器携带token(登录鉴权) -> 退出登录实现 -> token失效(401响应拦截) 1. 登录成…

crypto:RSA

题目 利用代码跑一下解码 import gmpy2 e 17 p 473398607161 q 4511491 d gmpy2.invert(e,(p-1)*(q-1)) print(d)总结 RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,常用于数据加密和数字签名。它基于两个大素数的乘积难以分解的数…

(数组 / 字符串) 55. 跳跃游戏 ——【Leetcode每日一题】

❓ 55. 跳跃游戏 难度:中等 给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标,如果可以,返回 true ;否则&#xff…

【基于Qt和OpenCV的多线程图像识别应用】

基于Qt和OpenCV的多线程图像识别应用 前言多线程编程为什么需要多线程Qt如何实现多线程线程间通信 图像识别项目代码项目结构各部分代码 项目演示小结 前言 这是一个简单的小项目,使用Qt和OpenCV构建的多线程图像识别应用程序,旨在识别图像中的人脸并将…

软件可靠性基础

软件可靠性基础 软件可靠性基本概念串并联系统可靠性计算软件可靠性测试软件可靠性建模软件可靠性管理软件可靠性设计容错,检错的技术 选择题考基本概念(MTBF),很少考 非重点 软件可靠性基本概念 这个章节中,第一个…

【数据库——MySQL】(6)查询(1)

目录 1. 数据库查询1.1 输出项为列名1.2 输出项为表达式1.3 输出内容变换1.4 消除输出项的重复行1.5 聚合函数 2. 查询条件:逻辑条件2.1 比较运算2.2 模式匹配2.3 范围限定2.4 空值判断 3. 分组3.1 基本分组3.2 分组汇总 4. 分组后筛选5. 输出行排序5.1 ORDER BY5.2…

识别车牌的代码分享

接口 接口为车牌的自动定位和识别,返回地域编号和车牌号车牌颜色: # pip install poocr import poocr # 可以填写本地图片的地址:img_path,也可以填写在线图片的地址:img_url # 如果2个都填,则只用在线图片img_url # configPath是配置文件的信息,可以不填 Number…

找高清、4K图片素材就上这6个网站,免费下载!

不会还有人找图片素材直接上网去搜吧,告诉你们6个网站,轻松找到想要的图片素材,不仅质量高,还可以免费下载,重点是还可以商用。赶紧收藏起来吧~ 1、菜鸟图库 https://www.sucai999.com/pic.html?vNTYwNDUx 网站主要为…

Scrapy+Selenium自动化获取个人CSDN文章质量分

前言 本文将介绍如何使用Scrapy和Selenium这两个强大的Python工具来自动获取个人CSDN文章的质量分数。我们将详细讨论Scrapy爬虫框架的使用,以及如何结合Selenium浏览器自动化工具来实现这一目标。无需手动浏览每篇文章,我们可以轻松地获取并记录文章的…

查询PCIE设备的VID,DID,SVID,SDID

查询PCIE设备的VID,DID,SVID,SDID ( Vendor ID、 Device ID、Subsystem Vendor ID、Subsystem Device ID ) [rootlocalhost ~]# lspci -s 04:00.0 -xxxvvv 04:00.0 Ethernet controller: Intel Corporation I210 Gigabit Network Connection (rev 03)C…

Docker部署ElasticSearch数据库+analysis-ik分词器插件

文章目录 一、部署ElasticSearch数据库二、添加分词器插件(analysis-ik)三、测试ElasticSearch数据库analysis-ik分词器插件 一、部署ElasticSearch数据库 1、准备工作 docker pull docker.elastic.co/elasticsearch/elasticsearch:7.17.6 Pwd"/data/software/elasticse…

Casper Network 构建企业级区块链生态的野望

Casper Network 是基于 Layer1 且图灵完备 Wasm 的智能合约平台,它由唯一可操作的 CBC-Casper Proof-of-Stake (PoS) 共识算法(称为 Highway)支持,该网络是一个无需许可、去中心化的公共区块链。 Casper Network 主网在 2021 年 4…

架构案例-架构真题2016(四十)

(2016)嵌入式处理器是嵌入式系统的核心部件,一般可分为嵌入式微处理器(MPU)微控制器(MCU)、数字信号处理器(DSP)和片上系统(SOC)。以下叙述中&…

一篇文章让你熟悉unordered_map及其模拟实现

熟悉unordered_map及其模拟实现 unordered_map的定义1. unordered_map的模板定义2. unordered_map的成员类型 unordered_map构造函数unordered_map赋值运算符重载unordered_map容量函数(Capacity)unordered_map迭代器(Iterators)1…

慢性疼痛治疗服务公司Kindly MD申请700万美元纳斯达克IPO上市

来源:猛兽财经 作者:猛兽财经 猛兽财经获悉,慢性疼痛治疗服务公司Kindly MD近期已向美国证券交易委员会(SEC)提交招股书,申请在纳斯达克IPO上市,股票代码为(KDLY),Kindly MD计划通过…