这篇文章整理来自http://bbs.chinaunix.net/thread-3675980-1-1.html

在论坛中看到的Android HAL讨论,有个ID描述的比较清楚,摘录如下:

tempname2发表于 2012-03-10 01:01:36 |只看该作者

Android的HAL就是很普通的中间层。它只不过把已经抽象的东西再抽象一次。硬件被操作系统抽象了,在LINUX中大抵体现在FS上。一般的情况是,操作系统对各种硬件作出统一接口设计,驱动程序实现这个接口。应用程序通过文件接口,继而通过驱动程序,操作硬件。所以驱动程序,广义上是让硬件工作的代码,狭义上是实现操作系统为此类硬件设计且期望的接口。

应用层看不到硬件或者驱动上的差别,因为它们最终呈现出的接口是一样的。而Android的hal则将这种机制再抽象一层:上层连文件系统接口都看不到了,只看得到Android设计的一套接口。这套接口在Linux上可能是对文件结点操作,如果有可以在其它操作系统上实现,也许会有其它形式。总之,跟之前的抽象一样,由于只看得到接口,因此只使用接口,只假定接口,接口以下的实现就不管了。针对接口操作,针对接口编程。

另外,HAL层在用户态的一个好处是,可以以闭源形式发布”驱动”。内核中的驱动代码仅暴露出基本的读写寄存器接口,这部分可以公开。而直正读写寄存器操作硬件的逻辑则在HAL层里实现,这部分则闭源发布二进制。

 
回复 10# mordorw

我做这个比较少,但恰好见过Marvell某平台的Camera HAL就是如此。内核态驱动就暴露一个文件结点,用IOCTL给它发命令,GET_REG,SET_REG等,所有的逻辑,比如说怎么设分辨率,怎么设曝光补偿,怎么设饱和度,怎么设情景模式,全在HAL层做,或者说在HAL层与驱动层中间那个层做。它确实是一个层了,这个层比Android Camera Framework层还要复杂一点,比这个Camera内核态V4l2的驱动要复杂很多很多很多。

至于不开源是为为了保护什么,我也不知道。像Windows这种大东西,它也不想发布源代码,也不至于用代码加密来保护吧,这可比加密驱动的后果要严重的多。

frame buffer已经不叫用户态驱动了,它内核规划的接口,驱动要实现这些接口功能。所谓用户态驱动,一般是说能在用户态操作硬件的。比如说I2C控制器,在内核态暴露接口,这个跟frame buffer有点像,但我通过这个文件接口可以向设备发消息。比如今天在这个I2C控制器上接了一个EEPROM,我拿着DATASHEET,在用户态就可以向它发命令,读写数据;明天在这个I2C控制器上接一个温度传感器,对着DATASHEET,我又可以在用户态读取温度。操作EEPROM,温度传感器的代码这时可全在用户态,这叫用户态驱动才恰当。甚至USB驱动也可以这样做,那可是万万千千的USB设备啊!我经历过的例子是三星的DNW,最早见到Linux下的版本由内核态驱动与用户态程序组成。可想而知编译内核模块多不方便。后来见到了完全在用户态实现的驱动,用户态编译一下,作为一个普通的用户态程序就可以用了,甚是方便。我自己甚至用Python写了DNW驱动+程序,总代码才40多行,这种层次的跳跃多么便利!

努力使用户态驱动变得可能,只是让人有这种选择而已,似乎不是一种趋势。

我写过Android APP。HAL不是为直接APP服务的,简单的说,Android中间层是Framework层,其大部分代码都是用Java写的。其中一部分类暴露出来可以被APP导入使用,大多数类都在后面经过层层抽象,协助暴露出的接口类完成任务。Framework有一小部分是C++代码,主要是为了和HAL层交互。不管再怎么抽象统一,最终落实下来,不同的硬件肯定要有不同的处理方法。从C++写的Framework到HAL后,路就分叉了。Android的Framework给APP抽象了一套接口,而这些接口的实现,平台无关的部分都已做完,平台相关的就滑到HAL里去了。所以HAL跟APP没有直接关系。

 
回复 12# mordorw

是的,就我举的那个例子而言,每一次IOCTRL自然是要陷入内核的。至于权限问题,我没想过,但Android用的是C/S模式,虽然每个程序(或者说acitiviy)都是一个独立的进程,它使用android提供的类并非直接与HAL层交互。比如camera相关类的拍照方法,sensor相关类得到数据的方法,这些方法无非是些被虚拟机执行的字节码,但字节码引起结果并非直接奔向HAL,而是奔向S。也就是说,APP调用的方法看起来执行了硬件相关操作,其实只是向特定的S发了一条消息而已。不同的硬件有不同的抽象,但肯定会有一个S。这个S可能是一个独立的进程,可能是一个进程内的线程之一。实际上,大部分情况是后者。所以S是非常有限且特定的,HAL以库的形式融于S所在进程之中,那么权限问题仅与几个特定进程有关。

回复 15# mordorw

与操作系统紧密相关的东西不可避免要出现在内核态。我举Marvell某平台应该是个极端例子。话说回来,通行的说法是,HAL层是Google为了响应硬件厂商想绕过GPL作出来的,其实就算没有这种事,总会有个像HAL一样的中间层存在。就像我之前说的,再怎么抽象,最终落实下来,还是要面对不同平台需要不同处理。隔离可变的,平台相关的东西,最简单的方法就是插入中间层。就算是为了便于Android在不同平台上的实现,也一定会有HAL这种东西。

到底有多少厂家真得用HAL来隐藏自己驱动的逻辑呢?我所接触平台不多,但正好碰到一个这样搞的。也做过x86平台的Android,它的HAL层就很干净。

整理: Android HAL的更多相关文章

  1. android HAL 教程(含实例)

    http://www.cnblogs.com/armlinux/archive/2012/01/14/2396768.html Android Hal 分析                       ...

  2. 【转】Android HAL实例解析

    原文网址:http://www.embedu.org/Column/Column339.htm 作者:刘老师,华清远见嵌入式学院讲师. 一.概述 本文希望通过分析台湾的Jollen的mokoid 工程 ...

  3. Android Hal 分析

    本文是基于android4.0.3.对应其他低版本的代码,可能有所差异,但基本大同小异. Android的HAL是为了保护一些硬件提供商的知识产权而提出的,是为了避开linux的GPL束缚.思路是把控 ...

  4. Android Hal层简要分析

    Android Hal层简要分析 Android Hal层(即 Hardware Abstraction Layer)是Google开发的Android系统里上层应用对底层硬件操作屏蔽的一个软件层次, ...

  5. 〖Android〗OK6410a的Android HAL层代码编写笔记

    一.编写LED灯的Linux驱动程序代码 之所以使用存在HAL层,是为了保护对硬件驱动过程的逻辑与原理: 所以,残留在Linux驱动层的代码,只保留了基本的读写操作,而不含有关键的逻辑思维: 1. l ...

  6. I.MX6 GPS Android HAL Framework 调试

    I.MX6 GPS Android HAL Framework 调试 一.参考文章: android4. GPS定位问题 http://blog.csdn.net/bzw073/article/det ...

  7. Android HAL实例解析

    一.概述 本文希望通过分析台湾的Jollen的mokoid 工程代码,和在s5pc100平台上实现过程种遇到的问题,解析Andorid HAL的开发方法. 二.HAL介绍 现有HAL架构由Patric ...

  8. 收集整理Android开发所需的Android SDK、开发中用到的工具、Android开发教程、Android设计规范,免费的设计素材等。

    AndroidDevTools Android Dev Tools官网地址:www.androiddevtools.cn 收集整理Android开发所需的Android SDK.开发中用到的工具.An ...

  9. Android HAL模块实现

    1. HAL介绍 Android的HAL(Hardware Abstract Layer硬件抽象层)是为了保护一些硬件提供商的知识产权而提出的.是为了避开linux的GPL束缚. 思路是把控制硬件的动 ...

随机推荐

  1. Citrix 虚拟化笔记

    利用win7 x64/Vmware workstation 10练习Citrix虚拟化 [安装Xenserver 6.2] 1)硬盘空间不足:要求最小8G 2)不支持硬件虚拟化:找到建立的XENSER ...

  2. 黑马程序员——OC语言 核心语法(1)

    Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结) (一)点语法 点语法其实本质上还是方法调用 当使用点语法时,编译器会自动展 ...

  3. 从0到1---“保多多”APP的开发(一)

    2015年8月份,我正式接手了公司保多多APP的开发(和另一个同事一起). 我之前并没有过从0开始创建一款APP,这次能有这样的机会,实在让我感到兴奋.因为我相信,作为这款APP的主要开发人员,在这一 ...

  4. ArrayList与普通数组的区别

    import java.util.ArrayList; public class Shuzuqubie { public static void main(String[] args){ String ...

  5. 复制过来的东西也不靠谱,微信公众号第三方平台的API

    API:https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&veri ...

  6. javaweb--上传文件UploadServlet1.java

    package cn.itcast.web.servlet; import java.io.File;import java.io.FileOutputStream;import java.io.IO ...

  7. [Java Basics] multi-threading

    1, Process&Threads Most implementations of the Java virtual machine run as a single process. Thr ...

  8. CCSprite setTextureRect 的坐标的坑

    setTextureRect显示区域所使用的坐标系是跟cocos2d-x的系统坐标系是有区别的,这个坐标系使用的一般屏幕坐标系,也就是以左上角为原点(0,0). Sprite的AnchorPoint对 ...

  9. 台球游戏的核心算法和AI(2)

    前言: 最近研究了box2dweb, 觉得自己编写Html5版台球游戏的时机已然成熟. 这也算是圆自己的一个愿望, 一个梦想. 承接该序列的相关博文: • 台球游戏核心算法和AI(1) 同时结合htm ...

  10. 怎样创建FTP服务器

    怎样创建FTP服务器 2008-05-06 08:42永远的探索|分类:操作系统/系统故障| 浏览6382次 我准备用局域网内的一台机器做FTP服务器,创建FTP服务器一定要用Windows serv ...