Android - lock/unlock bootloader

在执行 adb remount 时高版本经常会提示失败

 此时就需要对设备的进行解锁操作。记录两个部分,Google解锁和展锐解锁。

目录

一、Google解锁

二、展锐解锁

三、补充跳过按键检测的方案


一、Google解锁

官网介绍的unlock方法如下:锁定/解锁引导加载程序  |  Android Open Source Project

简单总结一下需要的步骤如下:

1、进入引导加载程序

adb reboot bootloader

2、解锁引导加载程序(设备处于lock状态,进行unlock)

fastboot flashing unlock

3、锁定引导加载程序(设备处于unlock状态,进行lock)

fastboot flashing lock
二、展锐解锁

我们使用的是展锐的芯片,根据以上步骤操作会提示未知的命令,如下图:

查阅了相关的 《Android 12.0 Secure Boot使用指南V1.0.pdf》、《Android 14 Secure Boot使用指南V1.0.pdf》 都有介绍详细流程。这里根据自己理解记录下需要的操作。

 1、进入引导加载程序

adb reboot bootloader

2、获取当前手机的id  

fastboot oem get_identifier_token

 3、生成解锁凭证 certificate.bin(ubuntu环境下)

脚本路径为:vendor/sprd/tools/packimage_scripts

秘钥路径为:bsp/tools/secureboot_key/config/rsa4096_vbmeta.pem

vendor/sprd/tools/packimage_scripts$ ./signidentifier_unlockbootloader.sh 上一步获取到的id ../../../../bsp/tools/secureboot_key/config/rsa4096_vbmeta.pem certificate.bin

4、PC上执行如下的解锁指令,需要在设备侧按音量下键确认

fastboot flashing unlock_bootloader certificate-b.bin

然后重启设备即可。

 5、PC上执行如下的锁定指令

fastboot flashing lock

注意:需要使用平台编译生成的 fastboot,编译指令为 make fastboot。生成路径为out/host/windows-x86

三、补充跳过按键检测的方案
bsp/bootloader/lkdiff --git a/app/sprdboot/fastboot.c b/app/sprdboot/fastboot.c
index 7291950a..679bb2b8 100755
--- a/app/sprdboot/fastboot.c
+++ b/app/sprdboot/fastboot.c
@@ -3137,12 +3137,15 @@ void fb_cmd_flashing(const char *arg, void *data, uint64_t sz)fastboot_okay("Bootloader has been locked!\n");return;}
-
+               // lichang 忽略按键选项,直接lock 
+               /*@start*/lcd_printf("\n   Warning: lock device may erase user data.\n");
+               lcd_printf("\n   Ignore key.\n");
+               /*lcd_printf("   Press volume down button to confirm that.\n");lcd_printf("   Press volume up button to cancel.\n");while(!butt_check) {
-                       /* continue check till button pressed */
+                       *//* continue check till button pressed *//*key_code = wait_for_keypress();if (key_code == KEY_VOLUMEDOWN) {butt_check = true;
@@ -3151,7 +3154,8 @@ void fb_cmd_flashing(const char *arg, void *data, uint64_t sz)fastboot_okay("Info:user cancel lock bootloader!   ");return;}
-               }
+               }*/
+               /*@end*/lcd_printf("   Begin to erase user data...\n");if (0 != common_raw_erase("userdata", 0, 0)) {debugf("erase userdata failed\n");
@@ -3191,11 +3195,15 @@ void fb_cmd_flashing(const char *arg, void *data, uint64_t sz)return;}+               // lichang 忽略按键选项,直接lock 
+               /*@start*/lcd_printf("\n   Warning: lock device may erase user data.\n");
+               lcd_printf("\n   Ignore key.\n");
+               /*lcd_printf("   Press volume down button to confirm that.\n");lcd_printf("   Press volume up button to cancel.\n");while(!butt_check) {
-                       /* continue check till button pressed */
+                       *//* continue check till button pressed *//*key_code = wait_for_keypress();if (key_code == KEY_VOLUMEDOWN) {butt_check = true;
@@ -3204,7 +3212,8 @@ void fb_cmd_flashing(const char *arg, void *data, uint64_t sz)fastboot_okay("Info:user cancel lock bootloader!   ");return;}
-               }
+               }*/
+               /*@end*/lcd_printf("   Begin to erase user data...\n");if (0 != common_raw_erase("userdata", 0, 0)) {debugf("erase userdata failed\n");
@@ -3259,10 +3268,14 @@ void fb_cmd_flashing(const char *arg, void *data, uint64_t sz)//memset(product_sn_signature, 0, sizeof(product_sn_signature));lcd_printf("\n   Warning: Unlock device may erase user data.\n");
+               //lichang 忽略按键,直接unlock
+               /*@start*/
+               /*
+               lcd_printf("   Ignore key.\n");lcd_printf("   Press volume down button to confirm that.\n");lcd_printf("   Press volume up button to cancel.\n");while(!butt_check) {
-                       /* continue check till button pressed */
+                       *//* continue check till button pressed *//*key_code = wait_for_keypress();if (key_code == KEY_VOLUMEDOWN) {butt_check = true;
@@ -3271,7 +3284,8 @@ void fb_cmd_flashing(const char *arg, void *data, uint64_t sz)fastboot_okay("Info:user cancel unlock bootloader!   ");return;}
-               }
+               }*/
+               /*@end*/lcd_printf("   Begin to erase user data...\n");if (0 != common_raw_erase("userdata", 0, 0)) {debugf("erase userdata failed\n");

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

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

相关文章

RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测-迅为电子

随着人工智能和大数据时代的到来,传统嵌入式处理器中的CPU和GPU逐渐无法满足日益增长的深度学习需求。为了应对这一挑战,在一些高端处理器中,NPU(神经网络处理单元)也被集成到了处理器里。NPU的出现不仅减轻了CPU和GPU…

Linux基础环境开发工具gcc/g++ make/Makefile git

1.Linux编译器-gcc/g使用 1. 预处理(进行宏替换) 预处理功能主要包括宏定义,文件包含,条件编译,去注释等。 预处理指令是以#号开头的代码行。 实例: gcc –E hello.c –o hello.i 选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。 选项“-o”是指目标…

【Java数据结构】---二叉树OJ

乐观学习,乐观生活,才能不断前进啊!!! 我的主页:optimistic_chen 我的专栏:c语言 ,Java 欢迎大家访问~ 创作不易,大佬们点赞鼓励下吧~ 文章目录 相同的树另一颗树的子树翻…

linux死锁问题和cpu使用率过高问题排查

1、问题共同点 死锁问题和cpu使用率过高都是需要我们找出对应的问题线程。 死锁问题需要我们找出哪两个线程出现了死锁情况。 cpu使用率过高需要我们找出哪个或哪些线程占用了大量的cpu。 2、命令排查 2.1、查看机器上的Java进程 jcmd或 jps2.2、查看对应Java进程的线程级别…

五子棋理解C++思想

双人五子棋项目目录: class Game { public:Game();void init();bool waitPlayerPutChess(Player* player, int& oldi, int& oldj);void draw();void play();bool isOver(int playerId);public:int whoWin -1; // 谁赢了(0:白棋&a…

科创中心“核”动力|趋动科技:AI算力界的领跑者

近日,趋动科技与深信服正式推出联合解决方案。联合解决方案将深信服EDS的高性能存储与趋动科技OrionX AI算力资源池化软件、以及GeminiAI训练平台有机结合,整合存力与算力资源的同时,帮助用户建好AI平台、管好AI资源、用好AI服务。 双方已完成…

Web3链上聚合器声呐已全球上线,开启区块链数据洞察新时代

在全球区块链技术高速发展的浪潮中,在创新发展理念的驱动下,区块链领域的工具类应用备受资本青睐。 2024年8月20日,由生纳(香港)国际集团倾力打造的一款链上应用工具——“声呐链上聚合器”,即“声呐链上数…

Facebook的区块链战略:如何在社交媒体中实现去中心化

随着区块链技术的发展,Facebook(现Meta)正积极探索如何将这一技术整合进其社交平台中,以提升用户体验和数据安全。区块链技术以去中心化、透明性和不可篡改性为特点,为社交媒体带来了新的可能性。本文将探讨Facebook在…

嵌入式和单片机有什么区别?

目录 (1)什么是嵌入式? (2)什么是单片机? (3)嵌入式和单片机的共同点 (4)嵌入式和单片机的区别 (1)什么是嵌入式? 关…

Linux云计算 |【第二阶段】SECURITY-DAY1

主要内容: 监控基础(系统监控命令、监控软件)、Zabbix监控服务端部署、Zabbix监控客户端部署、创建监控主机、调用监控模板、自定义key、创建模板、应用集、监控项、绑定模板; 一、监控概述 1)监控的目的 ① 实时报…

【Hot100】LeetCode—114. 二叉树展开为链表

目录 1- 思路技巧——借助指针 2- 实现⭐114. 二叉树展开为链表——题解思路 3- ACM 实现 原题连接:114. 二叉树展开为链表 1- 思路 技巧——借助指针 思路:通过 ① 将左子树的右下结点的 .next ——> 拼接到当前节点的右子树上。 构造 cur 指针&a…

数据结构【链试结构二叉树】

🌟个人主页:落叶 目录 ​编辑 实现链式结构⼆叉树 前中后序遍历: 遍历规则 代码实现 前序遍历: 中序遍历: 后序遍历: 图解遍历: 函数递归栈帧图: 结点个数以及高度等 【⼆…

每日OJ_牛客_淘宝网店(日期模拟)

目录 牛客_淘宝网店(日期模拟) 解析代码 牛客_淘宝网店(日期模拟) 淘宝网店__牛客网 解析代码 这是一个变相的日期计算器。只不过2、3、5、7、11月算1天,其他7个月算2天。 既然是一个变相的日期计算器,那…

基于STM32开发的智能空气质量监测系统

目录 引言环境准备工作 硬件准备软件安装与配置系统设计 系统架构硬件连接代码实现 系统初始化空气质量监测与处理风扇控制与状态显示Wi-Fi通信与远程监控应用场景 家庭和办公室的空气质量监测室内空气净化器的智能控制常见问题及解决方案 常见问题解决方案结论 1. 引言 空气…

单位信息宣传考核投稿方法不对让我尝尽了苦头

自从我担任单位的信息宣传员以来,便深刻体会到“信息宣传”四个字背后的重量。每月的信息宣传考核任务就像一座大山,压在我心头。起初,我像大多数同行一样,习惯于通过电子邮件向各大媒体投稿,但这种方式让我尝尽了苦头。 记得开始尝试通过邮箱投稿时,我满怀信心地将精心准备的文…

web前端之选项卡集合、动态添加类名、动态移除类名、动态添加样式、激活、间距、节流、tabBar

MENU input的checked属性(HtmlStyle)伪元素(HtmlStyleJavaScript)激活类(HtmlStyleJavaScript)vue伪元素 input的checked属性(HtmlStyle) 前言 代码段创建一个使用HTML和CSS实现的标签式内容切换组件。通过选择不同的标签,可以展示相应的内容。 代码段实现一个简洁…

02 tkinter有趣项目-头像制作-界面设计

头像制界面设计 avatar.png 界面 界面分析 背景图片: 顶部中央位置显示一个小孩背着书包的图片。这个图片是程序的背景,占据了大部分的窗口空间。 标题和按钮: 在图片上方,有一个标题栏,显示文本“在线姓氏头像制作”,使用隶书字…

redis面试(二十)读写锁WriteLock

写锁WriteLock 和读锁一样,在这个地方执行自己的lua脚本,我们去看一下 和read没有多大的区别 KEYS[1] anyLock ARGV[1] 30000 ARGV[2] UUID_01:threadId_01:write hget anyLock mode,此时肯定是没有的,因为根本没这个锁 …

“双指针”算法下篇

WeChat_20240806081335 对双指针这一思想在OJ 里面的相关应用,感兴趣的友友们,可以看下此篇博客 https://blog.csdn.net/X_do_myself/article/details/141291451?spm1001.2014.3001.5502 目录 一盛最多水的容器 1题目链接:盛最多水的容器…

音频分割软件有什么?最方便的音频分割软件分享给你

一段长音频就像是一本厚重的百科全书,而音频剪辑师的任务,就是要将这本书拆分成数个章节,每章都有其独立的主题和内容,这非常考验剪辑师们的音频分割技巧。 幸运的是,随着技术的发展,市面上出现了许多优秀…