Android AOSP 架构和各层次开发内容介绍

一、系统架构总况​​​​

官方文档:架构概览  |  Android Open Source Project (google.cn)icon-default.png?t=O83Ahttps://source.android.google.cn/docs/core/architecture?hl=zh-cn

下面是Google Android 提供的最新架构层次图:

AOSP 的软件堆栈
图. AOSP 的软件堆栈层次

System API 表示仅供合作伙伴和 OEM 纳入捆绑应用的 Android API。这些 API 在源代码中被标记为 @SystemApi。

Android API 是面向第三方 Android 应用开发者的公开 API。详情请参阅 Android API 参考文档。

层次(自上而下)

LayerComment

Apps

应用层

通过 Android API 或 System API 与FW交互。

- Android Apps:仅使用Android API来开发的应用。

- Privileged Apps:特权应用,使用Android和系统API组合创建的应用,必须预安装在设备上。

Device Manufacturer Apps:设备制造商应用,使用Android和系统API并直接访问Android框架实现而创建的应用(此类APP可以之间跟FW交互,不一定有中间层API,可能会直接访问Android FW中不稳定的API),必须原装在设备上,并且只能在设备的系统软件更新时进行更新。

Android Framework

框架层

构建应用所依据的一组 Java 类、接口和其他预编译代码。

框架的某些部分可通过使用 Android API 公开访问。

框架的其他部分只能由 OEM 通过系统 API 来访问。

Android 框架代码在应用进程内运行。

System Service

系统服务

系统服务是重点突出的模块化组件,例如 system_server、SurfaceFlinger 和 MediaService。

Android 框架 API 提供的功能可以与系统服务进行通信,以访问底层硬件。

Android Runtime

系统运行库层(ART)

AOSP 提供的 Java 运行时环境。

ART 会将应用的字节码转换为由设备运行时环境执行的处理器专有指令

HAL 硬件抽象层

HAL 是一个抽象层,其中包含硬件供应商要实现的标准接口。

HAL 让 Android 无需关注较低级别的驱动程序实现。

借助 HAL,可以顺利实现相关功能,而不会影响或更改更高级别的系统。详情参阅 HAL 概览。

System Service and Daemons

系统服务和守护进程

Daemons 守护进程。

该层中的原生守护程序包括 inithealthdlogd 和 storaged。这些守护程序直接与内核或其他接口进行交互,并且不依赖于基于用户空间的 HAL 实现。

该层中的原生库包括 libclibloglibutilslibbinder 和 libselinux。这些原生库直接与内核或其他接口进行交互,并且不依赖于基于用户空间的 HAL 实现。

Linux Kernel 内核层

抽象层,存在软硬件之间。驱动。

内核是任何操作系统的中心部分,并与设备上的底层硬件进行通信。尽可能将 AOSP 内核拆分为与硬件无关的模块和特定于供应商的模块。

AOSP 内核组件的说明(包括其定义)详情请参阅内核概览。

Android 大致可以分为四层架构:(2020年《第一行代码(第3版)》 ,比Google少了硬件抽象层的描述)

  1. Linux内核层
  2. 系统运行库层
  3. 应用框架层
  4. 应用层

按照Google 之前提供,Android 系统架构分为五层:(自上而下)

  1. 应用层
  2. 应用架构层
  3. 系统运行库层
  4. 硬件抽象层
  5. Linux内核层
图:Android 系统架构
图. Android 系统架构

二、各层级说明

(一)应用层 APP

与用户直接交互,支持Java和Kotlin开发。

(二)应用架构层 FW

该层由Java语言代码编写,提供上层应用程序需要的API(Application Programming Interface)。

开发工程师需要熟悉常用的系统服务组件。

  • ActivityManaer
  • PackageManager
  • TelephonyManager
  • ....

(三)系统运行库层 ART

该层包含 native C/C++ 和 Android 运行时库两部分。

Native C/C++ 原生程序库
  • OpenGL ES
  • Media Framework

Android Runtime 运行时库

Runtime Library 又分为核心库(Core Libraries)和ART。Android 5.0 之后,Dalvik虚拟机被ART取代。

(四)硬件抽象层 HAL/HIDL

位于OS内核和硬件电路直接的接口抽象层。屏蔽不同硬件厂商的差异,因此特定平台的硬件接口细节,为OS提供虚拟的硬件平台,实现多平台可移植性。

该层可以实现软硬件测试工作,包含完成控制硬件的动作操作。

(五)内核层 LK

Android 的核心服务都基于 Linux 内核,

- Android 内核基于上游 Linux 长期支持 (LTS) 内核。在 Google,LTS 内核会与 Android 专用补丁结合,形成所谓的“Android 通用内核 (ACK)”。

- 较新的 ACK(版本 5.4 及更高版本)也称为 GKI 内核。GKI 内核支持将与硬件无关的通用核心内核代码和 GKI 模块与硬件专用供应商模块分离开来。

- GKI 内核会与包含系统芯片 (SoC) 和板级代码的硬件专用供应商模块进行交互。GKI 内核与供应商模块之间的交互通过内核模块接口 (KMI) 来实现,该接口由标识供应商模块所需的函数和全局数据的符号列表组成。图

下图显示了 GKI 内核和供应商模块架构:

图 1. GKI 架构
图. GKI 架构

内核有多种类型(但是看不懂ACK等等),参考:内核概览  |  Android Open Source Project (google.cn)icon-default.png?t=O83Ahttps://source.android.google.cn/docs/core/architecture/kernel?hl=zh-cn#gkik

Android 通用内核 (ACK)

Android 通用内核  |  Android Open Source Project (google.cn)icon-default.png?t=O83Ahttps://source.android.google.cn/docs/core/architecture/kernel/android-common?hl=zh-cn

ACK 是长期支持 (LTS) 内核的下游,包含与 Android 社区相关但尚未合并到 Linux Mainline 或 LTS 内核的补丁。较新的 ACK(版本 5.4 及更高版本)也称为 GKI 内核,因为它们支持将与硬件无关的通用内核代码和与硬件无关的 GKI 模块分离开来。

Android 开源项目 (AOSP) 内核详情请参阅 Android 通用内核。

软件开发能看懂的内核说明:

功能内核

确保实现平台版本功能的内核。例如,在 Android 12 中,两个功能内核为 android12-5.4 和 android12-5.10。Android 12 功能无法向后移植到 4.19 内核,功能集与在发布时搭载 R 4.19 并升级到 S 的设备类似。

启动内核

对于启动指定 Android 平台版本的设备有效的内核。例如,在 Android 12 中,有效的启动内核为 4.19、5.4 和 5.10。

在软件项目开发中,遇到“kernel升级”的开发工作也就是这一层。比如K419升级到K510,是由于Android 系统版本功能支持性决定的。

旧版内核在AOSP中定义是指小于等于4.19的版本,详见说明参见下文。

旧版内核 (<=4.19)  |  Android Open Source Project (google.cn)icon-default.png?t=O83Ahttps://source.android.google.cn/docs/core/architecture/kernel/previous-kernel-overview?hl=zh-cn

长期支持 (LTS) 内核

受支持 2 到 6 年的 Linux 内核。LTS 内核每年发布一次,是 Google 每个 ACK 的基础。

另外官网还提到了分支,软件开发关注被mainline的部分,因为其内功能不能客制化,因此OEM需要寻找这部分的解决方案,不然只能follow Google。

图. Android 内核分支类型
图. Android 内核分支类型

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

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

相关文章

shell编程--永久环境变量和字符串显位

环境变量 echo $HOME 在终端输出后会显示家目录有个root变量 我们会提出个疑问为什么平时我们在终端输入sl 或者which等等命令会输出一些内容呢&#xff0c;这是因为这些命令都有对应的环境变量。 我们查看一下环境变量 在终端输入&#xff1a; echo $PATH 我们看一下输出…

【QT】解决生成的exe文件出现“无法定位程序入口”或“找不到xxx.dll”的问题

【QT】解决生成的exe文件出现“无法定位程序入口”或“找不到xxx.dll”的问题 零、问题 使用QT编译好项目后&#xff0c;想直接在文件资源管理器中运行exe程序或想分享出去给别人使用发现出现如下问题&#xff1a; 系统错误&#xff1a;找不到xxx.dll。 无法找到入口&#x…

【网络】什么是路由器 (Router )网关设备(Gateway)?

路由器&#xff08;Router&#xff09;&#xff0c;又称路径器或网关设备&#xff08;Gateway&#xff09;&#xff0c;是一种重要的计算机网络设备。以下是关于路由器的详细解释&#xff1a; 一、路由器的定义与功能 定义&#xff1a;路由器是连接因特网中各局域网、广域网的…

GitLab 降级安装出现 500 错误,如何解决?

本文分享 GitLab 中文版在降级的过程中出现 500 错误的修复方法。 写在前面 强烈不建议大家自行降级&#xff0c;如果真有降级需求&#xff0c;要么自己能力过硬&#xff0c;要么寻求专业服务【https://dl.gitlab.cn/cm33bsfv】&#xff0c;要不出问题很麻烦&#xff01; 问…

TensorFlow 2.0 windows11 GPU 训练环境配置

前言 在一切开始之前&#xff0c;请确保你的cmd命令行和powershell命令行可以正常打开。如果不能&#xff0c;建议重装系统。我不确定这是否会影响你最终的结果&#xff0c;毕竟windows的坑太多了。 安装顺序&#xff1a;visual studio -> cuda -> cudnn -> python…

前馈神经网络 (Feedforward Neural Network, FNN)

代码功能 网络定义&#xff1a; 使用 torch.nn 构建了一个简单的前馈神经网络。 隐藏层使用 ReLU 激活函数&#xff0c;输出层使用 Sigmoid 函数&#xff08;适用于二分类问题&#xff09;。 数据生成&#xff1a; 使用经典的 XOR 问题作为数据集。 数据点为二维输入&#xff…

《操作系统 - 清华大学》3 -3:连续内存分配:内存碎片与分区的动态分配

文章目录 0. 概述1. 内存碎片问题2. 动态分配3. 首次适配算法4. 最优适配算法5. 最差适配算法 0. 概述 内存分配是操作系统管理过程中很重要的环节&#xff0c;首先需要考虑的是一块连续区域分配的过程&#xff0c;这个过程中会有很多问题&#xff0c;首先比较关注的一个问题是…

[Mysql基础]表的查询

一、表的增删改查 CRUD : Create(创建), Retrieve(读取)&#xff0c;Update(更新)&#xff0c;Delete&#xff08;删除&#xff09; 1.1 插入否则更新 由于 主键 或者 唯一键 对应的值已经存在而导致插入失败 -- 创建一张学生表 CREATE TABLE students (id INT UNSIGNED PR…

信息安全工程师(83)Windows操作系统安全分析与防护

一、Windows操作系统安全分析 系统漏洞&#xff1a; Windows操作系统由于其复杂性和广泛使用&#xff0c;可能存在一些已知或未知的漏洞。这些漏洞可能会被黑客利用&#xff0c;进行恶意攻击。微软会定期发布系统更新和补丁&#xff0c;以修复这些漏洞&#xff0c;提高系统的安…

Excel超级处理器:高效实现2种批量生成二维码方式

在Excel数据处理中&#xff0c;二维码的批量生成是一个常见且重要的需求。借助Excel超级处理器这一强大的插件&#xff0c;用户可以轻松实现二维码的两种主要批量生成方式&#xff1a;直接在单元格中显示二维码图片&#xff0c;以及直接生成二维码图片并保存在文件夹中。超级处…

vue+svg圆形进度条组件

vuesvg圆形进度条组件 一、实现思路二、ProgressCircle.vue三、父组件使用四、实现效果 一、实现思路 使用svg的circle元素画两个圆形&#xff0c;一个圆形控制进度&#xff0c;一个绘制底色 二、ProgressCircle.vue 代码示例&#xff1a; <template><!-- 圆形进度…

react+hook+vite项目使用eletron打包成桌面应用+可以热更新

使用Hooks-Admin的架构 Hooks-Admin: &#x1f680;&#x1f680;&#x1f680; Hooks Admin&#xff0c;基于 React18、React-Router V6、React-Hooks、Redux、TypeScript、Vite2、Ant-Design 开源的一套后台管理框架。https://gitee.com/HalseySpicy/Hooks-Adminexe桌面应用…

如何基于Tesseract实现图片的文本识别

在前一篇文章基础上&#xff0c;如何将报告图片中的文本解析出来&#xff0c;最近研究了基于Tesseract的OCR方案&#xff0c;Tesseract OCR是一个开源的OCR引擎&#xff0c;主要结合开源的tesseract和pytesseract&#xff0c;实现了jpg/png等格式图片文本识别&#xff0c;供大家…

Vue中template模板报错

直接<v出现如下模板&#xff0c;出现如下错误 注意两个地方&#xff1a; 1.template里面加一个div标签 2.要写name值 如下图

地质旅游平台推动“旅游+地质”融合发展

2024年元旦假期&#xff0c;哈尔滨文旅市场持续火爆。据哈尔滨市文化广电和旅游局大数据测算&#xff0c;截至1月1日&#xff0c;哈尔滨市累计接待游客304.79万人次&#xff0c;实现旅游总收入59.14亿元&#xff0c;游客接待量与旅游总收入达到历史峰值。 夏有进“淄”赶烤&…

Linux源码阅读笔记-V4L2框架基础介绍

V4L2视频设备驱动基础 V4L2 是专门为 Linux 设备设计的整套视频框架&#xff08;其主要核心在 Linux 内核&#xff0c;相当于 Linux 操作系统上层的视频源捕获驱动框架&#xff09;。为上层访问系统底层的视频设备提供一个统一的标准接口。V4L2 驱动框架能够支持多种类型设备&…

机器学习day2-特征工程

四.特征工程 1.概念 一般使用pandas来进行数据清洗和数据处理、使用sklearn来进行特征工程 将任意数据&#xff08;文本或图像等&#xff09;转换为数字特征&#xff0c;对特征进行相关的处理 步骤&#xff1a;1.特征提取&#xff1b;2.无量纲化&#xff08;预处理&#xf…

机器学习 - 为 Jupyter Notebook 安装新的 Kernel

https://ipython.readthedocs.io/en/latest/install/kernel_install.html 当使用jupyter-notebook --no-browser 启动一个 notebook 时&#xff0c;默认使用了该 jupyter module 所在的 Python 环境作为 kernel&#xff0c;比如 C:\devel\Python\Python311。 如果&#xff0c…

w038基于SpringBoot的网上租赁系统设计与实现

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0…

【AI图像生成网站Golang】JWT认证与令牌桶算法

AI图像生成网站 目录 一、项目介绍 二、雪花算法 三、JWT认证与令牌桶算法 四、项目架构 五、图床上传与图像生成API搭建 六、项目测试与调试(等待更新) 三、JWT认证与令牌桶算法 在现代后端开发中&#xff0c;用户认证和接口限流是确保系统安全性和性能的两大关键要素…