Android的linux内核解耦

news2024/11/18 6:00:43

1、boot内容

查看Boot Image Header,version 2版本包含内容最多,包括了内核、设备树、根目录、recovery设备树,cmdline。boot拆包与内容解析参考1、Android bootimg kernel(boot.img)

2、linux的ramdisk解耦

2.1、ramdisk加载情况

2.1.1、android 13没有recovery分区

vendor_boot的ramdisk,init_boot 的ramdisk,boot镜像的GKI,system的tmpfs共同加载到RAM。根据命令参数选择正常Boot Android还是Boot recovery。

2.1.2、 android 13 AB系统有recovery分区情况

Boot Android还是加载vendor_boot的ramdisk,init_boot 的ramdisk,boot镜像的GKI,system的tmpfs;

Boot recovery加载vendor_boot的ramdisk,init_boot 的ramdisk,boot镜像的GKI,system的tmpfs以及recovery ramdisk。

2.1.3、android 13 non-AB系统有recovery情况

Boot Android还是加载vendor_boot的ramdisk,init_boot 的ramdisk,boot镜像的GKI,system的tmpfs;

Boot recovery加载recovery的GKI和ramdisk,boot镜像的GKI与tmpfs;

2.2、 ramdisk加载解析

上面三张图来自android开发者社区,显然大家很难看懂,我们抓下面三个关键来看图:

1、init分了两个阶段,每个阶段使用不同的资源文件,Android和recovery模式均是两个阶段。

2、启动必然要kernel,这个kernel在哪个分区?

3、进入recovery的核心二进制文件/system/bin/recovery以及它的资源文件在哪个分区?

相关内容所在分区整理表格如下

android 13

无recovery分区

android13 AB

有recovery分区

android 13 non-AB

有recovery分区

android模式

1nd init

init_boot分区

init_boot

init_boot

1nd resource

vendor_boot&init_boot

init_boot

init_boot

2nd init

system

system

system

2nd resource

system

system

system

kernel

boot kernel

boot kernel

boot kernel

recovery模式

1nd init

init_boot分区

recovery ramdisk

recovery ramdisk

2nd init

init_boot

recovery ramdisk

recovery ramdisk

kernel

boot kernel

boot kernel

recovery kernel

recovery二进制执行文件

vendor_boot

recovery ramdisk

recovery ramdisk

recovery resource

vendor_boot

recovery ramdisk

recovery ramdisk

2.3、ramdisk加载总结

根据上表分析:

1、android模式加载流程基本相同,init第二阶段均需要是用system里面的ramdisk;

2、recovery模式,有recovery分区则1nd init、2nd init、recovery执行文件与资源文件从recovery加载、否则1nd init、2nd init从init_boot加载,recovery执行文件与资源文件从vendor_boot加载;

3、没有recovery分区情况和AB系统情况一直使用同一内核boot GKI,non-AB系统有recovery分区情况在recovery模式下使用recovery的GKI。

3、linux的Kernel解耦

上图就是android的kernel解耦情况。目前虚线还未实现。

generic Kernel是Linus Torvalds维护的linux宏内核、GKI Modules是android定制模块,合称GKI;GKI对外接口是KMI;Vendor Modules是动态加载模块,通过KMI与GKI通信。

但是目前动态加载模块加载与执行效率并不理想,andorid还在优化。

这章关键在理解linux的分支管理与动态加载模块,以及KMI接口。内容多引用官网。

3.1 GKI

android底层是linux,这个linux除Linus Torvalds维护的宏内核外还有下面三方的修改:

1、android system针对linux的定制性修改,例如低内存终止守护进程(一个内存管理系统,可更主动地保留内存)、唤醒锁定(一种 PowerManager 系统服务)、Binder IPC 驱动程序、启动验证用的设备映射dm-mapper、OTA升级用的设备映射快照dm-snapshot、文件系统加密用的fscrypt等等;

2、芯片厂商vendor添加的内核方案,包括电源管理/DVFS、系统基础支持、PCIe和USB等高速外围设备等等;

3、ODM/OEM也有自己内核的方案,例如各家的驱动、外设方案。

现在google要脱离芯片厂商与ODM/OEM影响,对linux进行解耦。

3.2 KMI

3.3 GKI Modules与Vendor Modules

其实都是linux动态加载模块(不知道的自己查询),关键点在KMI的规范与稳定。

system的GKI模块,放置到system_dlkm里面,开机挂载分区安装,system_dlkm编译参考https://source.android.google.cn/docs/core/architecture/partitions/gki-partitions

将新功能配置为 GKI 模块

对于新功能,编辑gki_defconfig并将所需内核功能的配置项从n设置为m ( =m )。在arch/arm64/configs/gki_defconfig和arch/x86/configs/gki_defconfig中设置此设置。
将为该功能生成的 KO ( .ko ) 文件添加到common/modules.bzl的COMMON_GKI_MODULES_LIST部分。按排序顺序添加文件。如果您不确定生成的所有文件,构建将失败并列出要添加到列表中的所有必需的 KO 文件。
将步骤 2 中的同一组 KO 文件添加到common/android/gki_protected_modules以将模块指定为受保护的 GKI 模块,在运行时按升序排序以进行二进制搜索。指定为受保护 GKI 模块的模块仍必须经过 Google 批准才能成为官方受保护模块。
将步骤 2 中的同一组 KO 文件添加到common/android/gki_system_dlkm_modules ,以在运行时按升序排序以进行二进制搜索,以确保将文件复制到内核的out/<androidX-YZ>/dist/system_dlkm.img和out/ androidX-YZ /dist/system_dlkm_staging_archive.tar.gz 。 system_dlkm_staging_archive.tar.gz存档中的模块可用作输入以在平台构建中生成system_dlkm.img 。
提交您的更改以供审核。 GKI 模块是 Android 独有的内核功能,因此不需要向上游提交模块转换补丁。但是,您必须遵循其他准则来提交 Android 通用内核 (ACK) 补丁。

vendor添加动态加载模块官网地址

https://source.android.google.cn/docs/core/architecture/partitions/vendor-odm-dlkm-partition

添加vendor动态加载模块规则

https://source.android.google.cn/docs/core/architecture/kernel/vendor-module-guidelines

4、dtb与dtbo

android系统对dtb也有依赖,例如system、vendor等的挂载、验证。之前写过dtb与dtbo,并示范多层设备叠加层。

https://blog.csdn.net/dongyi1988/article/details/103995862#t1

5、BootConfig

BootConfig这个和cmdline一样,将配置详细信息从aboot传递到 Android 12 的机制。

现在与android相关的启动参数androidboot.*从内核 cmdline 移至 bootconfig 文件。

配置参考https://source.android.google.cn/docs/core/architecture/bootloader/implementing-bootconfig#examples-and-source

比较简单,我解析如下:

  1. kernel header是V4才能用;

  1. 可在/proc/bootconfig与设备树initramfs 节点查看信息;

  1. 在linux的/proc下有文件,显然有bootconfig内核模块。

6、总结

上面提到的ramdisk、kernel、dtb、BootConfig都进行了隔离,只是KMI还不够完善。

希望ODM/OEM善于利用这种隔离。

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

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

相关文章

Python学习笔记——文件操作

输入和输出Python两种输出值的方式: 表达式语句和 print() 函数。第三种方式是使用文件对象的 write() 方法&#xff0c;标准输出文件可以用 sys.stdout 引用。如果你希望输出的形式更加多样&#xff0c;可以使用 str.format() 函数来格式化输出值。如果你希望将输出的值转成字…

H3C路由器带宽保证(命令行)配置方法

1 配置需求或说明 1.1适用产品系列 本案例适用于如MSR810、MSR93X系列的路由器。 1.2配置需求及实现的效果 某企业路由器接入业务有语音业务、管理部门业务和普通业务。要求当网络出现拥塞时&#xff0c;语音业务加速转发&#xff0c;管理部门业务确保转发&#xff0c;剩余或…

小满OKKICRM与金蝶云星空对接集成客户档案

小满OKKICRM与金蝶云星空对接集成客户列表查询(更新列表)&客户新增(小满客户对接金蝶客户-P)数据源平台:小满OKKICRM小满科技成立于2013年&#xff0c;是阿里巴巴集团战略投资的高新技术企业。小满科技以“人工智能大数据”为核心驱动力&#xff0c;为外贸企业提供智能CRM解…

合并所有重叠的区间

Python-合并区间 题目 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 示例 1: 输入&#xff1a;interva…

【Ajax】模板引擎

一、模板引擎的基本概念渲染UI结构时遇到的问题var rows [] //遍历空数组 $.each(res.data, function (i, item) { // 循环拼接字符串rows.push(<li class"list-group-item"> item.content <span class"badge cmt-date">评论时间&#xff1a;…

87.序列到序列学习(seq2seq)以及代码实现

1. 机器翻译 2. Seq2Seq 双向RNN可以做encoder&#xff0c;但不能做decoder。 3. 编码器-解码器细节 4. 训练 5. 衡量生成序列的好坏的BLEU 上面的公式既加入了段序列的惩罚项&#xff0c;又加入了更难出现的长序列的高权重。 6. 总结&#xff1a; Seq2seq从一个句子生成另一…

【网络通信】【电信运营商实战工程师】思科设备篇-网络工程师必备基础知识

电信运营商实战工程师系列文章. 思科设备篇-网络工程师必备基础知识. 文章目录1. 电信运营商网络设备机房2. 认识并管理运营商网络设备3. GNS3 安装与配置4. IPv4地址及子网划分 VLSM-CIDR 详解5. OSI 七层参考模型及进制转换技巧1. 电信运营商网络设备机房 知识点&#xff1a;…

win-bat批处理命令

基本知识 cmd 与 powershel 命令和关键字不区分大小写&#xff0c;变量名区分大小写 DOS 是磁盘操作系统&#xff1b;命令提示符是 DOS 系统的界面中输入 DOS 命令的提示位置&#xff1b;cmd 是系统运行其自带 DOS 的命令 PID 是 processid&#xff08;进程号&#xff09;&am…

36-剑指 Offer 38. 字符串的排列

题目 输入一个字符串&#xff0c;打印出该字符串中字符的所有排列。 你可以以任意顺序返回这个字符串数组&#xff0c;但里面不能有重复元素。 示例: 输入&#xff1a;s "abc" 输出&#xff1a;["abc","acb","bac","bca&quo…

二维前缀和数组二维差分数组

二维前缀和数组&二维差分数组 一维前缀和 用途&#xff1a;快速求出数组中nums[i,j]nums[i,j]nums[i,j]元素之和 定义&#xff1a;sums[i1]sums[i1]sums[i1]为nums数组前iii个元素之和 sums[i1]∑j0inums[j]sums[i 1] \sum _{j0} ^{i}nums[j] sums[i1]j0∑i​nums[j] …

神经网络——day67:Residual Network

Deep Residual Learning for Image RecognitionDeep Residual Learning for Image Recognition1. Introduction2. Related WorkResidual Representations(剩余表示).Shortcut Connections(快捷连接).3. Deep Residual Learning3.1. Residual Learning3.2. Identity Mapping by …

Java项目:学生管理系统

Java项目&#xff1a;学生管理系统一、学生管理系统基础版需求1. 初始菜单2. 学生类&#xff1a;3. 添加功能&#xff1a;4. 删除功能&#xff1a;5. 修改功能&#xff1a;6. 查询功能&#xff1a;代码1. 学生类2. 测试类输出结果a. 添加b. 删除c. 修改d. 查询e. 退出二、学生管…

前端监控 二三事

有必要针对 JS 错误做监控吗&#xff1f; 我们可以先假设不对 JS 错误做监控&#xff0c;试想会出现什么问题&#xff1f; JS 错误可能会导致渲染出错、用户操作意外终止&#xff0c;如果没有 JS 错误监控&#xff0c;开发者完全感知不到线上这些异常情况。特别是像电商、支付…

【2-神经网络优化】北京大学TensorFlow2.0

课程地址&#xff1a;【北京大学】Tensorflow2.0_哔哩哔哩_bilibiliPython3.7和TensorFlow2.1六讲&#xff1a;神经网络计算&#xff1a;神经网络的计算过程&#xff0c;搭建第一个神经网络模型神经网络优化&#xff1a;神经网络的优化方法&#xff0c;掌握学习率、激活函数、损…

7. 字符串str的详细讲解

python3字符串str的使用 (1) 基本使用 [a]. Python 中单引号 和双引号 " 使用完全相同&#xff1b; [b]. 使用三引号(单或双)可以指定一个多行字符串&#xff1b; # 长字符串 print( jkl fsf fs fs )[c]. 反斜杠可以用来转义&#xff0c;使用r(raw)可以让反斜杠…

【LeetCode高频100题-3】冲冲冲(持续更新23.1.19)

文章目录62. 不同路径题意解法1 排列组合解法2 动态规划62. 不同路径 题意 一道数学题&#xff0c;排列组合/小学奥赛题。动态规划不是一般来解决最值问题的吗&#xff0c;这道题为什么会想到dp&#xff1f; 解法1 排列组合 从左上角到右下角&#xff0c;一共要走mn-2步&am…

DEJA_VU3D - Cesium功能集 -完整地图标绘及编辑功能系列预告

前言编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合&#xff0c;有自己琢磨实现的&#xff0c;也有参考其他大神后整理实现的&#xff0c;初步算了算现在有差不多实现小140个左右的功能&#xff0c;后续也会不断的追加&#xff0c;所以暂时打算一周2-3更的样…

【算法】克鲁斯卡尔 (Kruskal) 算法

目录1.概述2.代码实现2.1.并查集2.2.邻接矩阵存储图2.3.邻接表存储图2.4.测试代码3.应用本文参考&#xff1a; 《数据结构教程》第 5 版 李春葆 主编 1.概述 &#xff08;1&#xff09;在一给定的无向图 G (V, E) 中&#xff0c;(u, v) 代表连接顶点 u 与顶点 v 的边&#xf…

【6s965-fall2022】剪枝✂pruningⅠ

模型剪枝的介绍 修剪&#xff0c;消除不必要的知识。DNN的知识可以理解为存在于其权重中。 事实证明&#xff0c;许多 DNN 模型可以被分解为权重张量&#xff0c;而权重张量经常包含统计冗余&#xff08;稀疏性&#xff09;。因此&#xff0c;你可以压缩 DNN 的权重张量&…

[从零开始]用python制作识图翻译器·五

测试 通过以上步骤我们终于实现了系统&#xff0c;现在到了紧张刺激的测试环节。直接运行run.py文件: python run.py ::注意需要进入conda环境稍作等等&#xff0c;我们的系统就运行啦&#xff08;啵唧啵唧&#xff09;。 在使用之前&#xff0c;我们还需要在设置中输入自己的…