基于安卓的非标准驱动程序设计

发布者:gamma14最新更新时间:2013-10-23 来源: eefocus关键字:硬件抽象层  JNI技术  Android 手机看文章 扫描二维码
随时随地手机看文章
Android系统是Google推出的基于Linux内核和Java架构的操作系统,在很短的时间内已成为主流的手机操作系统,并已逐步扩展应用到嵌入式系统、平板电脑和上网本上。它既有Linux系统所具有的硬件平台可移植性,也因使用Java语言开发应用程序带来了应用软件只编写一次即可在所有平台运行的巨大优势。Android虽然主要基于已有的技术,但在体系结构设计上有较大的创新。其主要设计目标之一就是要使应用程序和系统能独立于具体的计算机体系结构和硬件平台,表现在设备驱动程序设计上,对于已有的Linux标准设备驱动程序可以直接继续使用,只需为其增加应用层JNI接口。但对于Linux没有的非标准设备则提倡在Linux内核中驱动部分只做很少的接口工作,尽量把驱动程序的主要处理放在Android的上层架构中,即在应用层实现。本文对Android系统的底层实现技术进行深入的研究,包括Android的硬件抽象层和JNI技术实现等。并以S3C2440开发板上的LED灯设计显示驱动程序为例,提出了一种非标准硬件设备驱动程序的设计和实现方案。

1 Android系统驱动程序架构

1.1 驱动程序分层体系结构

Android是基于Linux的,它使用了Linux内核,但应用程序使用Java语言开发,所以应用程序在调用设备驱动时不能像一般的Linux应用程序那样直接使用系统调用,必须通过Java虚拟机的JNI的本地(Native)方法使用设备。另一方面,Android要成为一个通用性强的平台,必须加强它的可移植性。这也是在Android架构添加一个硬件抽象层(HAL)的原因,目的是为设备的调用提供一个更高级的封装图1所示为Android驱动程序架构。
HAL Stub是以Linux共享库(*.so)的形式存在,在整个驱动架构中,它是设备驱动程序运行在用户空间的一部分,它向上为Dalvik虚拟机提供硬件设备的抽象接口,向下通过系统调用与Linux内核中的驱动程序进行数据交互。在这个过程中HAL可以对驱动程序的数据进行处理,也就是说在Linux内核中的驱动程序部分只需要提供一个与硬件设备传输数据接口的功能,而其余具体的操作可以由HAL完成。

1.2 Android的硬件抽象层

Android的硬件抽象层HAL(Hardware Abstract Layer)在Android的架构中是在库这一层中,通过这一层,硬件厂商可以把部分设备的驱动源码封装在这一层而不公开源代码。

对图1分析,设计HAL就是为了把应用框架和Linux内核分离出来,让Android使用Linux内核而又不完全依赖Linux内核。当然,驱动程序并不是完全从Linux内核中分离出来,一些基本的处理必须由内核来完成,HAL只是分担了Linux设备驱动的部分功能,至于这部分的功能占驱动程序功能的比例目前并没有一个标准。

在Android系统发展过程中,HAL的实现也逐步有了一些变化,旧的HAL是一种模块化的思想,通过共享库的形式由Runtime在JNI时以函数调用方法调用,这种做法并没有通过封装,即上层应用可以直接调用硬件。另外,这种方法可被多个进程使用,映射到多个进程空间中浪费内存资源。

现在HAL提出一种Stub的思想,HAL Stub是一种代理的概念,Stub同样是以共享库(*.so)格式存在,但上层应用并不像加载动态库那样调用Stub。这种HAL是由模块与Stub结合而成,Runtime通过模块提供的统一接口获取并操作Stub。Stub向HAL提供操作的回调函数,Runtime向HAL取得指定模块的操作函数后,调用这些回调函数。这是一种间接函数调用的方式,HAL里包含了多个Stub。图2为HAL Stib原理。


1.3 Android的JNI实现原理

JNI是Java Native Interface的缩写,是在Sun的Java平台中首先定义出来的,它允许Java代码与其他语言代码进行交互。Android中JNI的设计目的也是一样:

(1) 应用程序需要与硬件平台交互时,Java库中的类不可能支持;
(2) 本地已经使用其他语言编写的库允许Java程序访问;
(3) 某些功能用较低级的语言实现的执行效率较高,让Java程序调用这些函数。

在Android应用层中的程序或组件都是用Java语言开发的,这些Java代码编译后变成Dex格式的字节码,由Dalvik虚拟机执行,在执行过程中需要调用本地库时,由虚拟机载入这些本地库,然后让Java函数调用库中的函数,虚拟机相当于一座桥梁,让Java与本地库能够透过标准的JNI界面互相沟通。

应用程序在虚拟机里执行,通过函数System.loadLibrary( )通知虚拟机载入指定的库,例如在Java代码中包含代码如:
… …
System.loadLibrary(“sample_jni”);
… …
虚拟机就会在Android文件系统的“/system/lib/”目录中查找libsample_jni.so库文件,虚拟机载入libsample_jni.so后,Java代码就可以与库文件结合起来一起执行。

这些用C语言编写的本地库必须遵循规范,当虚拟机执行System.loadLibrary()函数时,首先执行本地库里的JNI_OnLoad()函数,这个函数需要实现的功能是:返回给虚拟机此本地库使用的JNI版本;对库进行初始化。如果本地库里没有实现JNI_OnLoad()函数,虚拟机就会默认本地库使用最老的JNI 1.1版本。

JNI_OnUnload()函数与装入函数相对应,在虚拟机释放该本地库时,会调用JNI_OnUnload()函数进行资源回收动作。

在应用层的Java代码通过虚拟机调用本地函数,一般要依赖于虚拟机查找库里的本地函数,如果需要调用比较频繁,每次都要寻找一遍,就会花费较多的时间影响效率,在这里可以通过registerNativeMethods()函数把gMethods[]表格所含的本地函数注册到虚拟机里。

2 Android硬件驱动程序设计

Android是一个开放平台,在嵌入式移动设备领域里具有很好的应用前景,但在不同的设备上往往有不同的硬件支持,要在Android中添加这些硬件应用,不是单纯地在Linux内核中添加驱动模块,还必须在用户空间和应用框架中添加对应的支持。下面以给S3C2440开发板添加一个LED显示控制驱动功能为例展示Android平台添加新硬件支持的过程。

2.1 硬件驱动程序的框架

LED控制功能通过应用程序来开关开发板上的LED灯。在应用层中LED控制程序调用LED控制服务(Android Service),应用层中的LED控制服务通过JNI让虚拟机加载LED控制的本地库,然后向HAL获取LED Stub,由Stub调用在Linux内核中的LED驱动。图3为LED控制功能的架构设计。[page]

从LED控制功能的架构来分,整个功能可以分成五个模块:LED驱动模块、LED Stub模块、LED本地服务模块、LED服务管理模块和LED应用模块。

2.2 HAL中的Stub的设计与实现

图4是LED Stub的实现过程。LED Stub是硬件抽象层中LED控制的代理,当LED控制的本地服务需要调用LED Stub时,通过函数hw_get_module( )结合LED Stub的模块ID向HAL申请LED Stub,本地服务获得Stub对象后,可以把Stub看作一个抽象硬件进行操作。

下面是定义LED Stub的HAL结构体:
struct led_module_t {
struct hw_module_t common;
}
struct led_module_t {
struct hw_module_t common;
int fd;
int(*ns_set_on)(struct led_control_device_t*dev,int32_t led);
int(*ns_set_off)(struct led_control_device_t*dev,int32_t led);
}

将结构体led_module_t初始化一个实例名为HAL_MODULE_INFO_SYM,这个名称不能修改,实例里包含了Stub的模块信息,主要包括:

tag:标记了结构体的类型,这里的值为HARDWARE_MODULE_TAG;
id:LED Stub的模块ID,在本地服务向HAL获取Stub时调用的函数hw_get_module()中,通过这里的id查找LED Stub;
methods:是结构体hw_module_methods_t的实例,为HAL定义回调函数open()。
这里的open()函数是一个必须实现的回调函数接口,在本地服务获得Stub对象后调用,它负责申请结构体led_control_device_t的空间,填充信息,注册具体操作的回调函数接口并打开LED驱动。
结构体led_control_device_t继承了hw_device_t,在open()函数调用时填充的主要信息包括:
tag:结构体的类型,这里的值为HARDWARE_DEVICE_TAG;
module:Stub的模块,也就是实例HAL_MODULE_INFO_SYM中的hw_module_t部分;
close:释放LED Stub的回调函数;
fd:打开设备驱动文件返回的文件描述符;
ns_set_on:打开LED灯的回调函数指针;
ns_set_off:关闭LED灯的回调函数指针。

回调函数指针“*ns_set_on”和“*ns_set_off”分别指向实现函数hal_ led_on()和hal_led_off(),在实现函数中通过系统调用ioctl()对LED灯进行开关控制。

2.3 硬件控制服务的JNI实现

LED控制本地库编译后为“libled.so”保存在Android文件系统的“/sysem/lib/”目录下面,LED控制服务的Android进程运行后由虚拟机实例装入本地库,具体实现过程如图5所示。

LED控制服务调用System.load()函数,它的虚拟机实例就会装入LED控制本地库,虚拟机会首先调用 JNI_OnLoad()函数完成:
(1) 把虚拟机环境信息保存到本地库的一个结构体“JNIEnv”的实例中;
(2) 建立一个应用层中的LED控制服务与本地库的JNI函数表;
(3) 返回虚拟机本地库使用的JNI版本。
加载完后,应用层中的LED控制服务就可以通过虚拟机中的JNI函数表把运行的Java函数转换为本地函数执行。在LED控制服务类中定义有JNI函数的方式,例如下面的代码段:
public final class LedService extends IledService.Stub {
…….
static {
System.load(“/system/lib/libled.so”);
}
……
private static native boolean as_init();
private static native boolean as_set_on(int led);
private static native boolean as_set_off(int led);
}

本文的研究工作是在S3C2440开发板上进行的,以给开发板上的LED灯增加驱动程序为例,展示了一种为Android平台非标准硬件增加驱动程序的设计方案,对于实现其他设备的驱动具有一定的借鉴意义。由于各种硬件设备及其接口差异较大,本文着重于驱动程序的设计方案,没有讨论相关的硬件接口驱动细节。随着Android平台日渐成熟以及应用数量的增加,它在嵌入式领域的应用范围将会更加广泛。为Android设备编写不同于标准Linux系统的设备驱动程序会变得越来越多。

关键字:硬件抽象层  JNI技术  Android 引用地址:基于安卓的非标准驱动程序设计

上一篇:基于Linux的视频监控系统构建方法
下一篇:基于AT91SAM9G20构建嵌入式Linux系统

推荐阅读最新更新时间:2024-03-16 13:29

鸿蒙并不是给手机设计的 外媒:华为无意开发安卓替代品
自华为被美国列入实体清单以来,有关鸿蒙操作系统替代安卓的消息就一直不绝于耳。不过,事实情况是,鸿蒙根本不是为智能手机而设计的,它主要为物联网开发,华为手机依然会继续使用安卓。外媒PA日前发文章表示,华为显然无意开发安卓的替代品。 日前,华为董事和高级副总裁陈黎芳在接受采访时明确表示,华为的鸿蒙操作系统不是为智能手机设计的,而是专为工业用途而设计,主要关注安全性和极低延时。 但外媒认为,尽管如此,如果谷歌被迫永久取消支持,预计在2019年末或2020年初的某个时候,华为会推出一个不受欢迎且未完成的的版本。 早先,在华为《2018年可持续发展报告》发布会上,谈及鸿蒙系统时,华为董事长梁华表示,这是为物联网开发的操作系统,是否发
[手机便携]
HMD Global:Android将让诺基亚再次伟大
        简单易用,坚固耐用,想必这是很多人对诺基亚手机的印象。在iPhone尚未问世之前,这家芬兰公司全球手机市场拥有绝对的统治力。然而今时不同往日,10年后的今天已经是Android智能手机的天下,诺基亚最终也选择向Android靠拢。当然,虽然系统变了,但是这并不意味着诺基亚的品质也变了。   当前诺基亚已经将手机品牌授权给了芬兰公司HMD Global,在未来10年内HMD将制造并销售诺基亚品牌手机,而近期HMD一名官员在接受采访时表示,诺基亚Android智能手机前路一片光明。   据外媒报道,HMD Global中东和北非副总裁Per Ekman日前向Gulf News表示,今年最新发布的诺基亚手机依旧保持着
[手机便携]
传华为正自研手机与PC操作系统,回应:重心还在安卓
今天早间,据南华早报援引知情人士消息,中国智能手机厂商华为一直在自主研发一款智能手机操作系统。 来自澎湃新闻最新报道称,华为方面向他们回应中称,在可预见的未来,华为没有发布自有OS(操作系统)的计划,“我们的重心在Android OS产品;我们对移动OS采取开放的态度。我们不断努力通过持续创新、行业开放合作为消费者提供优质的综合体验,并将致力于此。” 据此前南华早报消息,该知情人士表示,自从 2012 年美国对华为和中兴展开调查,华为就开始构建自己的操作系统,华为还开发了自己的平板电脑和个人电脑操作系统。 据称这项计划由华为 CEO 任正非发起,被视作“为最坏情况作准备”的战略投资。不过这名知情人士也表示,这款操作系统和 Andr
[手机便携]
开发者自述:一个Android Wear应用的设计经历
   开发者自述:一个Android Wear应用的设计经历   导语:美国Android Developer Blog周二刊登题为《一个Android Wear应用的设计故事》(An Android Wear Design Story)的文章,讲述了设计师罗曼·奴里克(Roman Nurik)和蒂莫西·乔丹(Timothy Jordan)第一次为Android Wear设计应用的经历。   以下为文章全文:   几周前,我和蒂莫西聊起如何为可穿戴设备设计应用,以便验证我们为Google I/O 2014大会规划的一些内容。在谈到这些设备如何能够同时吸引普通用户和开发者的关注时,我们聊了很多。我们还谈到了用户情景,以及如何让
[手机便携]
中国市场iOS韧性强 Android版本众多
      据国外媒体报道,美国科技记者Kim-Mai Cutler过去两个星期内走访了北京和上海等地,与木瓜移动、HappyLatte、PopCap和创新工场等企业就中国Android和iOS市场的发展进行了深入交流。   对于很多开发商来说,中国是仅次于美国的第二大市场。就移动开发商如何更好地开拓这个市场,Kim-Mai Cutler为Inside Mobile Apps撰写了《理解中国的iOS和Android市场》一文,分7点对中国市场进行了详细阐述,全文概要如下:   1)Android发展可能要任重而道远;虽然中国民众收入偏低,但iOS的发展表现出令人惊讶的韧性:   根据相关市场研究公司的数据,近几个月,iOS在百度的移
[手机便携]
Chrome OS将取代Android成为平板专用系统
近日,谷歌最新的Chrome 64位更新版本向Chromebook提供了一些非常必要的功能。 其中包括用于平板模式下的多任务处理,新的分屏功能以及Android一样的屏幕截图功能,这些虽然是相对基础的升级,但他们确实体现了Chrome OS的未来——Android平板电脑软件的替代品。 就目前而言,Chrome OS已经非常接近这个目标,而这样的功能促使其成为混合操作系统。 之前网络上就曝光了一款宏碁出品的Chrome OS平板电脑 ,看来谷歌确实是想延伸Chrome OS的泛用性。 谷歌的Chrome和Android团队已经进行了长时间的合作,以确保推出像Chromebook这样的二合一低成本计算机设备,简直两全其美。 去年,C
[嵌入式]
wifi分析仪android 9,Wifi分析仪(无线信号检测)
Wifi分析仪,一款检测工具,主要是针对wifi的强度进行检测,采用图通的图标形式对信号进行分析,分析不同的信道的流畅指数,还可以查看已经连接wifi的IP地址,十分的好用,快来下载吧。 【软件介绍】 这是Android系统上最专业的WIFI信号分析软件,有了这个软件,就可以把你的Android手机变成一个专业的,而且简单方便易用的WIFI信号分析仪器。使用本程序,你可以分析周围WIFI信号通道占用情况,帮助你给自己的无线路由器选择一个合适的通道,以获得更好的WIFI连接。 【软件功能】 1.提供不同方显示式的信号强度显示 2.提供局域网邻居,查询局域网的IP地址 3.提供不同信道的路线支持 4.支持个性化功能设置 【
[测试测量]
wifi分析仪<font color='red'>android</font> 9,Wifi分析仪(无线信号检测)
基于Dragonboard 410c android系统实现人的眼球识别功能
上一篇博客《基于Dragonboard410c 系统实现 camera图像预览》,我们实现了如何在410c android系统上进行USB camera图像的预览功能,本文在此基础上,我们借助openncv库,实现人的眼球识别功能。 一 准备工具: 图1.Dragonboard410c开发板(android系统) 图2. 图3.线 图4.罗技C525(usb camera) 二 移植opencv库: 1.地址:http://opencv.org/downlos.html 2.移植步骤:大家可以参照 Android 使用OpenCV的方法案例,包括如何可以通过省略openncv_
[机器人]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved