Android6.0&9.0 Wifi

在介绍Android9.0中wifi的架构之前,先介绍一下Android Treble项目。

Android系统架构

Android6.0&9.0 Wifi_第1张图片

1.应用框架。 应用框架最常被应用开发者使用。作为硬件开发者,您应该非常了解开发者 API,因为很多此类 API 都可以直接映射到底层 HAL 接口,并可提供与实现驱动程序相关的实用信息。
2.Binder IPC。 Binder 进程间通信 (IPC) 机制允许应用框架跨越进程边界并调用 Android 系统服务代码,这使得高级框架 API 能与 Android 系统服务进行交互。在应用框架级别,开发者无法看到此类通信的过程,但一切似乎都在“按部就班地运行”。
系统服务。系统服务是专注于特定功能的模块化组件,例如窗口管理器、搜索服务或通知管理器。 应用框架 API 所提供的功能可与系统服务通信,以访问底层硬件。Android 包含两组服务:“系统”(诸如窗口管理器和通知管理器之类的服务)和“媒体”(与播放和录制媒体相关的服务)。
3.硬件抽象层 (HAL)。 HAL 可定义一个标准接口以供硬件供应商实现,这可让 Android 忽略较低级别的驱动程序实现。借助 HAL,您可以顺利实现相关功能,而不会影响或更改更高级别的系统。HAL 实现会被封装成模块,并会由 Android 系统适时地加载。有关详情,请参阅硬件抽象层 (HAL) 一文。
4.Linux 内核。 开发设备驱动程序与开发典型的 Linux 设备驱动程序类似。Android 使用的 Linux 内核版本包含几个特殊的补充功能,例如:Low Memory Killer(一种内存管理系统,可更主动地保留内存)、唤醒锁定(一种 PowerManager 系统服务)、Binder IPC 驱动程序以及对移动嵌入式平台来说非常重要的其他功能。这些补充功能主要用于增强系统功能,不会影响驱动程序开发。您可以使用任意版本的内核,只要它支持所需功能(如 Binder 驱动程序)即可。不过,我们建议您使用 Android 内核的最新版本。有关详情,请参阅编译内核一文。

HIDL

Android 8.0 重新设计了 Android 操作系统框架(在一个名为“Treble”的项目中),以便让制造商能够以更低的成本更轻松、更快速地将设备更新到新版 Android 系统。在这种新架构中,HAL 接口定义语言(HIDL,发音为“hide-l”)指定了 HAL 和其用户之间的接口,让用户能够替换 Android 框架(android framework),而无需重新编译 HAL。

利用新的供应商接口,HIDL 将供应商实现(由芯片制造商编写的设备专属底层软件)与 Android 操作系统框架分离开来。供应商或 SOC 制造商构建一次 HAL,并将其放置在设备的 /vendor 分区中;框架可以在自己的分区中通过无线下载 (OTA) 更新进行替换,而无需重新编译 HAL。

Android6.0&9.0 Wifi_第2张图片

System update

1.旧版android升级
Android6.0&9.0 Wifi_第3张图片
旧版Android需要需要同时升级framework、vendor。

2.Android8.0+系统升级
Android6.0&9.0 Wifi_第4张图片
引入treble之后,只需升级framework。

Wifi 架构

Android6.0&9.0 Wifi_第5张图片

Wifi 启动过程分析

1.Android 6.0 Wifi启动过程
Android6.0&9.0 Wifi_第6张图片
2.Android 9.0 Wifi启动过程

Android6.0&9.0 Wifi_第7张图片

通过Wifi的启动过程,就能看到在Android8.0之后,wifi的启动更加的复杂。在系统中添加了与hal层相关的service,供framework层进行调用。主要原理就是为hal层添加了binder支持。

你可能感兴趣的:(android,Wifi,HIDL)