Android HIDL学习(1) --- 简介
Android HIDL学习 [1] --- 简介
一、简介
1.1 HIDL
HAL接口定义语言(简称HIDL)适用于指定HAL和其用户之间的接口的一种接口描述语言(IDL)。
HIDL允许指定类型和方法调用。
从更更烦的意义上来说HIDL适用于在独立编程的代码库之间通信的系统。
HIDL旨在用于进程间通信(IPC)。进程之间的通信经过Binder化。
对于必须与进程相关联的代码库,还可以使用直通模式。
HIDL可指定数据结构和方法签名,这些内容会整理归类到接口中,而接口会汇集到软件包中。尽管HIDL具有一系列不同的关键字,C++和JAVA程序员对HIDL的语法并不陌生。此外,HIDL还是用JAVA样式和注释。
1.2 HIDL设计
其实HIDL的出现是为了更好的服务于Treble这个项目,不了解Treble的可以先从网上找一下相关的资料,我这里简单做说明。
由于Android的发展比较迅猛,各大手机厂商和芯片厂商都在做,
Google当然作为一个领导者在指引我们做出更好的手机操作系统,但是由于版本太多,
Android版本的碎片化越来越严重,而且系统的更新又是一个耗时和复杂的过程,Google试图来解决这个问题而引入了Treble,
大家都知道做手机的,比如:小米,华为,VIVO等厂商,他们维护自己的BSP,
基本上他们的BSP包含几部分:
注意,这里的Framework是vendor修改过的,这样子的话,这四部分都耦合在一起,
因为Google每次更新Android大版本,基本上都是framework的升级,
与vendor改的代码理论上是可以独立开来的,
所以Google尝试通过Treble来独立更新system.img来帮助vendor更快的移植新的Android版本。
以前HAL是以so的形式存在的,作为一堆标准接口,供Android framework调用,
无论是通过jni还是别的途径,如果要被framework调用,那这些so就一定要存在于system分区,
但是我们现在要把system分区独立开来,
这样子,vendor修改的代码全部要在vendor分区,
所以,引入了HIDL来解决这个问题,vendor设计的HAL都以独立的service存在,
每一个HAL模块都是一个独立的binder server进程,
Android framework想用调用HAL的接口就必须作为binder的client来调用,
后面会详细描述,这里大家只要记住这个概念就OK。