第9章 硬件抽象层:HAL

Android的硬件抽象层,简单来说,就是对Linux内核驱动程序的封装,向上提供接口,屏蔽低层的实现细节。也就是说,把对硬件的支持分成了两层,一层放在用户空间(User Space),一层放在内核空间(Kernel Space),其中,硬件抽象层运行在用户空间,而Linux内核驱动程序运行在内核空间。为什么要这样安排呢?把硬件抽象层和内核驱动整合在一起放在内核空间不可行吗?从技术实现的角度来看,是可以的,然而从商业的角度来看,把对硬件的支持逻辑都放在内核空间,可能会损害厂家的利益。我们知道,Linux内核源代码版权遵循GNU License,而Android源代码版权遵循Apache License,前者在发布产品时,必须公布源代码,而后者无须发布源代码。如果把对硬件支持的所有代码都放在Linux驱动层,那就意味着发布时要公开驱动程序的源代码,而公开源代码就意味着把硬件的相关参数和实现都公开了,在手机市场竞争激烈的今天,这对厂家来说,损害是非常大的。因此,Android才会想到把对硬件的支持分成硬件抽象层和内核驱动层,内核驱动层只提供简单的访问硬件逻辑,例如读写硬件寄存器的通道,至于从硬件中读到了什么值或者写了什么值到硬件中的逻辑,都放在硬件抽象层中去了,这样就可以把商业秘密隐藏起来了。也正是由于这个分层的原因,Android被踢出了Linux内核主线代码树中。大家想想,Android放在内核空间的驱动程序对硬件的支持是不完整的,把Linux内核移植到别的机器上去时,由于缺乏硬件抽象层的支持,硬件就完全不能用了,这也是为什么说Android是开放系统而不是开源系统的原因。

撇开这些争论,学习Android硬件抽象层,对理解整个Android整个系统,都是极其有用的,因为它从下到上涉及到了Android系统的硬件驱动层、硬件抽象层、运行时库和应用程序框架层等等,下面这个图阐述了硬件抽象层在Android系统中的位置,以及它和其它层的关系:

Android加入HAL主要有如下的目的:

1.统一硬件的调用接口。由于HAL 有标准的调用接口,所以可以利用HAL:屏蔽Linux 驱动
复杂、不统一的接口。
2.解决了GPL版权问题。由于Linux 内核基于GPL协议,而Android 基于Apache Licence 2.0 协议.因此Google 玩了个“穿越“。将原本位于Linux驱动中的敏感代码向上移了一个层次。这样这些敏感代码就摆脱了GPL 协议的束缚, 那些不想开源的Linux驱动作者也就没必要开源了。
3.针对一些特殊的要求。对于有些硬件,可能需要访问一些用户空间的资源,或在内核空间不方便完成的工作以及特殊需求。在这种情况下,可以利用位于用户空间的HAL 代码来辅助Linux驱动完成一些工作。

编写一款支持HAL 的Linux 驱动程序的步骤

第1 步:编写Linux 驱动

第2 步:编写HAL Library

第3 步:编写Service Library

编写HAL 模块的步骤和原理

第1步:定义结构体和宏

编写HAL 模块需要使用到3 个非常重要的结构体( hw_module_t 、hw_device_t 和hw _ module_ methods_t ), 在第1步需要定义两个新的结构体, 这两个结构体的第1个变量的数据类型必须是hw_module_t 和hw_device_t。除此之外, 还需要为HAL 模块定义一个ID。

第2步:编写HAL 模块的open函数

open 函数是HAL 模块的入口点。

第3步:定义hw_module_methods_ t 结构体变量

HAL 模块需要hw_module_methods_t 结构体的open 函数指针交量指定open 入口函数。

第4步: 定义HAL_MODULE_INFO_SYM 变量

所有的HAL 模块都必须有一个HAL_MODULE_INFO_SYM 变量。

第5步:编写HAL 模块的close 函数

当HAL 模块被卸载后会调用close 函数。

第6步:编写控制LED 的函数

根据设备类型和功能的不同,这一步编写的函数也有所不同。

时间: 2024-08-06 20:08:12

第9章 硬件抽象层:HAL的相关文章

第九章 硬件抽象层:HAL

1.在传统的Linux系统中Linux驱动一般有两种类型的代码:访问硬件寄存器的代码和业务逻辑代码. 2.android的层次结构:应用层,应用框架层,系统运行库层,linux内核层 3.为android加入HAL的目的: (1)统一硬件的调用接口.由于HAL有标准的调用接口,所以可以利用 HAL屏蔽Linux驱动复杂,不统一的接口. (2)解决GPL版权问题.由于 Linux 内核基于GP协议,而Android基于Apache Licence2.0协议 (3)针对一些特殊的要求.对于有些硬件,

第7章 Android HAL实例解析

第7章 Android HAL实例解析 通过本章介绍Android的HAL知道HAL是为了一些硬件提供商提出的保护专利的驱动程序而产生的,是为了避开Linux的GPL束缚.HAL主要的存储目录有:1.libhardware_legany  2.libhardware:3.ril   4.msm7k.主要包含以下一些模块:Gps.Vibrator.Wifi.Copybit.Audio.Camera.Lights.Ril.Overlay等.大概了解了Android  HAL. 第1中方法 直接调用s

第九章 硬件抽象层:HAL

本章的主要内容是硬件抽象层:HAL.本章中了解的是编写HAL的Linux驱动程序的步骤,具体如下: 第一步:编写Linux驱动 “编写Linux驱动”,从表面上看没什么意义,但如果要为Linux驱动添加HAL,而且像尽量保护敏感数据.Linux驱动的代码就要尽量简洁,尽可能将业务逻辑放到HAL Library中. 第二步:编写HAL Library HAL Library就是普通的Linux Library(*.so)文件.但这类文件库有一个接口.通过HAL_MODULE_INFO_SYM变量实

第9章:硬件抽象层HAL

1.HAL ( Hardware Abstraction Layer,硬件抽象层) 是建立在Linux驱动之上的一套翻字库.这套程序库并不属于 Linux 内核, 而是属于 Linux 内核层之上的应用层. 2.编写一款支持 HAL 的 Linux 驱动程序的步骤 编写一款支持 HAL 的 Linux 驱动程序要比编写普通的 Linux 驱动程序复杂一些,加入HAL 会使组成 Linux 驱动的一整套 Library 的各部分更独立,更容易维护. 第 1 步:编写 Linux 驱动 “编写 Li

第九章 硬件抽象层:HAL 心得笔记

1.HAL(Handerware Abstraction Layer,硬件抽象层)是建立在linux程序上的一套程序库,这套程序库并不属于内核,而是属于内核之上的应用层. 2.要在Android中加入HAL的原因:在linux驱动中一般有两种类型的代码:访问硬件寄存器的代码和业务逻辑代码.对于访问硬件寄存器的代码而言,并没有秘密,这都是调用linux内核的标准函数进行的标准操作. 3.Google为android加入HAL其主要目的在于: 统一硬件的调用接口: 解决了GPL版权问题: 针对一些特

第九章 硬件抽象层: HAL

HAL ( Hardware Abstraction Layer,硬件抽象层 )是建立在Linux 驱动之上的一套程序库.这套程序库并不属于Linux 内核, 而是属于Linux 内核层之上的应用层. 统一硬件的调用接口.由于HAL 有标准的调用接口,所以可以利用HAL屏蔽Linux 驱动复杂.不统一的接口.解决了GPL版权问题.由于Linux 内核基于GPL协议,而Android 基于Apache Licence 2 .0 协议.因此Google 玩了个“穿越”,将原本位于Linux驱动中的敏

第九章 硬件抽象层:HAL 读后感

Android HAL层,即硬件抽象层,是Google响应厂家“希望不公开源码”的要求推出的新概念1,源代码和目标位置源代码: /hardware/libhardware目录,该目录的目录结构如下:/hardware/libhardware/hardware.c编译成libhardware.so,目标位置为/system/lib目录2,HAL层的实现方式JNI->通用硬件模块->硬件模块->内核驱动接口具体一点:JNI->libhardware.so->xxx.xxx.so-

第九章硬件抽象层:HAL

1.HAL是建立在Linux驱动之上的一套程序库,这套程序库并不属于Linux内核,而是属于Linux内核层之上的应用层. 2.Google为Android加入HAL主要有如下的目的: 统一硬件的调用接口.解决了GPL版权问题. 3.加入HAL的驱动使应用程序不需要再关心Linux驱动和设备文件的交互方式,而只需要像访问普通API一样就可以和Linux驱动进行交互. 4.编写一款支持HAL的Linux驱动程序的步骤: 第一步:编写Linux驱动. 第二步:编写HAL Library 第三步:编写

Android深度探索(卷1)HAL与驱动开发 第九章 硬件抽象层:HAL 读书笔记

HAL是建立在Linux驱动之上的一套程序库.这套程序库并不属于Linux内核,而是属于Linux内核层之上的应用层.HAL的主要目的一个是用来保护"私人财产",另一个是尽量避免应用程序直接访问Linux驱动程序. 传统的Linux系统中Linux驱动一般有两种类型的代码,访问硬件寄存器和业务逻辑代码.对于访问硬件寄存器代码,并无秘密可言,因为都是调用Linux内核的标准函数进行的标准操作.而Linux的业务逻辑部分对于有些企业或者个人并不想讲源代码公开.Linux内核采用GPL协议,