展示
从开机的时候,看提示,进入验证启动认知:
data:image/s3,"s3://crabby-images/db0de/db0dee6aea60ec441745f13876dd6628d15c888d" alt=""
data:image/s3,"s3://crabby-images/32444/32444133c9b00add5042536347174532c91b8208" alt=""
流程:
data:image/s3,"s3://crabby-images/962e5/962e581a827aeae65b89580ae3f0b2da3d81daa4" alt=""
目的
保护系统的安全性。
涉及的范围:从受硬件保护的信任根到引导加载程序,再到启动分区和其他已验证分区(包括 system、vendor 和可选的 oem 分区)的完整信任链。
实现的方式:
1.在设备启动过程中,无论是在哪个阶段,都会在进入下一个阶段之前先验证下一个阶段的完整性和真实性
2.检查是否存在内置了回滚保护的正确 Android 版本
3. Android 设备将其完整性状态传达给用户
理解框架
data:image/s3,"s3://crabby-images/ddafe/ddafe66267dc05f5a9462e344eeef0eb751b1e63" alt=""
实战
前言
data:image/s3,"s3://crabby-images/3a26d/3a26d7ad88b5c9f0759ac21d9c6d80b3f69b4956" alt=""
* Android P + kernel-4.4 or kernel-3.18
- download preloader with verified boot disabled which location is the same as scatter file //preloader_<PROJECT>_SBOOT_DIS.bin
- adb root
- adb disable-verity
- adb reboot
- adb root
- adb remount
* Android P + kernel-4.9 or after
- download preloader with verified boot disabled which location is the same as scatter file. //preloader_<PROJECT>_SBOOT_DIS.bin
- boot to Home Screen
- go to setting -> system -> Developer options -> OEM unlocking
- adb reboot bootloader
- fastboot flashing unlock
- press volume up key
- fastboot reboot
- adb root
- adb disable-verity
- adb reboot
- adb root
- adb remount
实例一:
效果展示:
data:image/s3,"s3://crabby-images/67bba/67bba0fbd2fe908062a453ef8f7234f4c36d0d42" alt=""
代码分析:
data:image/s3,"s3://crabby-images/b1237/b1237bd1fc7c5fc7fc29f32a64156e2be8ff8ed2" alt=""
快速验证方法:
data:image/s3,"s3://crabby-images/9c3f3/9c3f3e61a381481d270216ce6567cb9ecba882c6" alt=""
adb shell验证:
getprop ro.oem_unlock_supported
1---代表打开
0---代表关闭
data:image/s3,"s3://crabby-images/bad88/bad885d1a6251daaa4e90ef5433cac07fbf15fb4" alt=""
通过如下操作:
- adb reboot bootloader
- fastboot flashing unlock
- press volume up key
- fastboot reboot
之后:
adb shell
解锁成功后检查这两个属性会从
[ro.boot.flash.locked]: [1]
[ro.boot.verifiedbootstate]: [green]
变成
[ro.boot.flash.locked]: [0]
[ro.boot.verifiedbootstate]: [orange]
补充:
ro.boot.flash.locke在哪里进行改变的?
开机启动过程。具体为system/core/init/init.cpp
main(int argc, char** argv) {
·····
export_oem_lock_status();
·····
}
export_oem_lock_status(){
if (!android::base::GetBoolProperty("ro.oem_unlock_supported", false)) {
return;
}
std::string value = GetProperty("ro.boot.verifiedbootstate", "");
if (!value.empty()) {
property_set("ro.boot.flash.locked", value == "orange" ? "0" : "1");
}
}
实例二:
效果展示:
data:image/s3,"s3://crabby-images/dac71/dac71693379f133104f51260cc201dd865549ca0" alt=""
怎么让禁止解锁变成可以解锁的状态?
代码分析为什么变成禁止解锁状态?
data:image/s3,"s3://crabby-images/90640/906404c99a9c29e00187786ea5f1d5f63cb2450c" alt=""
具体方法:
1.直接操作/data/system/users/0.xml中的值:
UserManagerService.java中有对/data/system/users/0.xml进行处理
eg:
灰色的值:
<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<user id="0" serialNumber="0" flags="19" created="0" lastLoggedIn="0" profileBadge="0">
<restrictions no_oem_unlock="true" />
</user>
正常的值:
<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<user id="0" serialNumber="0" flags="19" created="0" lastLoggedIn="1548122734879" lastLoggedInFingerprint="alps//full_k61v1_64_bsp:9/PPR1.180610.011/1548115520:user/release-keys" profileBadge="0">
<restrictions />
</user>
即:
adb root
adb pull /data/system/users/0.xml 本地路径
修改0.xml中的值
adb push 本地修改之后的文件 /data/system/users/
adb reboot
就可以满足要求
2.代码实现的方式:
修改配置文件
UserManagerService.java的构建方法中:
UserManagerService(......)-->readUserListLP()--->fallbackToSingleUserLP()
详解:
fallbackToSingleUserLP(){
***********
Bundle restrictions = new Bundle();
try {
final String[] defaultFirstUserRestrictions = mContext.getResources().getStringArray(
com.android.internal.R.array.config_defaultFirstUserRestrictions);
for (String userRestriction : defaultFirstUserRestrictions) {
if (UserRestrictionsUtils.isValidRestriction(userRestriction)) {
restrictions.putBoolean(userRestriction, true);
}
}
} catch (Resources.NotFoundException e) {
Log.e(LOG_TAG, "Couldn't find resource: config_defaultFirstUserRestrictions", e);
}
********
}
原生为:
frameworks/base/core/res/res/values/config.xml
<string-array translatable="false" name="config_defaultFirstUserRestrictions">
</string-array>
gms包中overlay为:
gms_overlay/frameworks/base/core/res/res/values/config.xml
<string-array translatable="false" name="config_defaultFirstUserRestrictions">
<item>"no_oem_unlock"</item>
</string-array>
参考学习
https://source.android.com/security/verifiedboot/index.html
https://source.android.com/security/verifiedboot/verified-boot.html
https://source.android.com/security/verifiedboot/dm-verity.html
https://gitlab.com/cryptsetup/cryptsetup/wikis/DMVerity
https://blog.csdn.net/sinat_34606064/article/details/77920700
网友评论