《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > Android系統非標準設備驅動程序設計
Android系統非標準設備驅動程序設計
來源:微型機與應用2011年第14期
孟小華, 黃宗軒
(暨南大學 計算機科學系, 廣東 廣州510632)
摘要: 在深入研究Android硬件抽象層HAL和Java本地接口JNI技術原理的基礎上,提出了一個Android非標準硬件驅動程序的設計方案。以一個非標準設備的驅動程式的實現為例介紹了驅動程序的功能模塊分層設計,討論了使用HAL Stub技術對硬件抽象層HAL模塊進行優化的方法。
Abstract:
Key words :

摘   要: 在深入研究Android硬件抽象層HAL和Java本地接口JNI技術原理的基礎上,提出了一個Android非標準硬件驅動程序的設計方案。以一個非標準設備的驅動程式的實現為例介紹了驅動程序的功能模塊分層設計,討論了使用HAL Stub技術對硬件抽象層HAL模塊進行優化的方法。
關鍵詞: Android; 設備驅動程序; 硬件抽象層; JNI

    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控制功能的架構設計。

 

 

    從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系統的設備驅動程序會變得越來越多。
參考文獻
[1] BRADY P. Anatomy & physiology of an android[EB/OL].2008[2009-03-24].http://sites.google.com/site/io/anatomyphysiology-of-an-android.
[2] GREG K H. Android and the linux kernel community[EB/OL].[2010-02-02], http://www.kroah.com/log/linux/androidkernel-problems.html.
[3] 葉炳發, 孟小華. Android圖形系統的分析與移植[J]. 電信科學,2010(02):65-68.
[4] 李俊.嵌入式Linux設備驅動程序開發詳解[M]. 北京:人民郵電出版社,2008.
[5] 胡希明,毛德操. Linux內核源代碼情景分析[M]. 杭州:浙江大學出版社,2004.
[6] 姚昱旻, 劉衛國. Android的架構與應用開發研究 [D].長沙:中南大學,2008.
 

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国产一区二区三区黄| 亚洲一区二区三区四区视频| 欧美激情一区二区在线| 91久久精品视频| 欧美大学生性色视频| 亚洲一二三区精品| 久久躁日日躁aaaaxxxx| 亚洲成人在线视频网站| 国产欧美一区二区三区久久| 久久国产精品一区二区三区四区| 黄色综合网站| 黄色精品一区| 香蕉久久夜色精品国产| 欧美专区日韩视频| 国产欧美日韩三区| 欧美国产日韩a欧美在线观看| 欧美顶级艳妇交换群宴| 亚洲欧美日韩国产综合在线| 欧美日韩天天操| 欧美另类视频| 一级成人国产| 国产精品免费网站在线观看| 午夜精品亚洲| 久久久蜜桃一区二区人| 黄色精品一区| 狠狠色狠狠色综合日日五| 欧美96在线丨欧| 国产亚洲精品美女| 亚洲高清视频在线观看| 亚洲欧美偷拍卡通变态| 欧美日韩在线视频观看| 国产精品综合av一区二区国产馆| 国内精品久久久久影院 日本资源| 欧美精品一区二区三| 亚洲国产精品尤物yw在线观看| 免费欧美电影| 久久福利视频导航| 欧美成人精品高清在线播放| 亚洲欧洲av一区二区| 欧美视频三区在线播放| 国产免费成人av| 夜夜嗨av色综合久久久综合网| 一区二区三区四区蜜桃| 亚洲黄色成人| 欧美激情在线观看| 久久色中文字幕| 免费91麻豆精品国产自产在线观看| 欧美精品v日韩精品v韩国精品v| 欧美日韩性视频在线| 激情综合色丁香一区二区| 亚洲国产精品久久久久| 欧美成年人网| 亚洲国产成人久久综合一区| 欧美午夜a级限制福利片| 欧美三区在线视频| 国产农村妇女精品| 亚洲第一精品在线| 欧美激情综合网| 久久免费偷拍视频| 亚洲黄一区二区| 欧美精品国产精品日韩精品| 欧美伊人久久大香线蕉综合69| 亚洲免费在线看| 先锋a资源在线看亚洲| av不卡在线看| 国产精品久久91| 女人色偷偷aa久久天堂| 欧美午夜女人视频在线| 久久九九久精品国产免费直播| 欧美久久久久久久久| 久久香蕉精品| 久久精品一区二区三区不卡牛牛| 米奇777超碰欧美日韩亚洲| 欧美黄色一区| 亚洲一区二区三区国产| 欧美成人黄色小视频| 亚洲一区二区四区| 亚洲国产一区二区三区青草影视| 欧美在线播放高清精品| 一本色道久久综合精品竹菊| 一区二区三区|亚洲午夜| 国产免费成人av| 亚洲免费视频成人| 欧美日韩在线一区二区| 国产亚洲欧美日韩一区二区| 欧美三区在线视频| 亚洲影院在线观看| 久久成人18免费网站| 久久精品99久久香蕉国产色戒| 国产婷婷色一区二区三区在线| 国产精品丝袜xxxxxxx| 久久国产精品亚洲77777| 欧美a级大片| 99视频+国产日韩欧美| 尤物99国产成人精品视频| 国产色产综合色产在线视频| 久久爱www| 欧美精品一卡| 国产精品自拍视频| 亚洲国产美国国产综合一区二区| 悠悠资源网久久精品| 久久偷看各类wc女厕嘘嘘偷窃| 欧美黄色片免费观看| 免费亚洲婷婷| 亚洲一区二区视频在线观看| 国产专区欧美精品| 国产精品igao视频网网址不卡日韩| 国产日产高清欧美一区二区三区| 欧美色视频一区| 欧美日韩免费区域视频在线观看| 国产综合色精品一区二区三区| 国产日韩一区在线| 欧美日韩国产一级片| 亚洲最新色图| 久久久久久伊人| 欧美aaaaaaaa牛牛影院| 亚洲欧美精品在线| 亚洲国产99| 免费欧美高清视频| 亚洲国产美国国产综合一区二区| 在线观看欧美精品| 欧美一级淫片播放口| 亚洲黄一区二区| 亚洲视频电影图片偷拍一区| 欧美多人爱爱视频网站| 欧美jizz19hd性欧美| 亚洲国产精品国自产拍av秋霞| 国产精品毛片a∨一区二区三区| 你懂的视频一区二区| 欧美大片va欧美在线播放| 亚洲男女自偷自拍图片另类| 亚洲国产毛片完整版| 国产欧美精品va在线观看| av成人动漫| 亚洲欧美综合国产精品一区| 99国产精品私拍| 欧美日韩美女在线| 先锋a资源在线看亚洲| 中日韩视频在线观看| 国产精品一香蕉国产线看观看| 国产精品激情偷乱一区二区∴| 欧美片第一页| 亚洲欧美日韩在线综合| 亚洲第一精品福利| 99re6这里只有精品视频在线观看| 欧美三级视频在线观看| 亚洲精品永久免费| 在线精品在线| 国产精品高清一区二区三区| 欧美日韩中文字幕日韩欧美| 国产精品高潮在线| 国产精品你懂的在线欣赏| 欧美性猛交99久久久久99按摩| 狠狠爱成人网| 欧美日韩在线观看一区二区三区| 国产精品久久久久久妇女6080| 欧美日韩一区二区三区四区在线观看| 亚洲天天影视| 久久五月婷婷丁香社区| 久久久久久噜噜噜久久久精品| 亚洲五月六月| 久久久久久**毛片大全| 国产精品videossex久久发布| 亚洲九九九在线观看| 激情久久五月天| 亚洲精品久久久久| 亚洲一区二区三区国产| 欧美成人精品高清在线播放| 日韩亚洲一区二区| 久久午夜精品一区二区| 国产啪精品视频| 亚洲精品美女在线观看播放| 米奇777在线欧美播放| 久久综合中文字幕| 先锋影音久久久| 欧美日韩国语| 亚洲精品免费一二三区| 亚洲欧美自拍偷拍| 久久亚洲精品网站| 亚洲伦理在线观看| 欧美大片免费观看在线观看网站推荐| 亚洲清纯自拍| 在线观看视频欧美| 亚洲黄网站在线观看| 国产精品高潮呻吟视频| 国产精品久久久一区麻豆最新章节| 永久免费毛片在线播放不卡| 亚洲精品国产无天堂网2021| 午夜亚洲福利| 一本一本a久久| 1204国产成人精品视频| 欧美日韩另类国产亚洲欧美一级| 免费成年人欧美视频| 国产精品欧美在线| 媚黑女一区二区| 欧美成人精品在线视频| 久久精品视频在线观看| 亚洲欧美日韩国产综合精品二区| 欧美午夜a级限制福利片| 欧美刺激性大交免费视频| 亚洲第一天堂av| 欧美日韩久久精品| 亚洲久久视频| 国产综合色在线视频区| 久久久综合视频| 免费成人av资源网| 久久免费黄色| 在线看片一区| 欧美高清视频免费观看| 在线亚洲美日韩| 亚洲少妇自拍| 国产亚洲精久久久久久| 亚洲社区在线观看| 欧美不卡一区| 美日韩精品免费| 国产精品久久国产愉拍| 欧美日韩国产综合视频在线观看中文| 欧美精品九九99久久| 亚洲精品视频二区| 亚洲第一区在线| 性欧美1819sex性高清| 欧美二区在线看| 久久精品二区亚洲w码| 欧美一区深夜视频| 欧美在线观看视频一区二区三区| 一区二区三区高清在线观看| 亚洲欧美成人综合| 久久激情视频久久| 欧美午夜激情小视频| 久久一区二区三区四区| 国产精品麻豆成人av电影艾秋| 欧美日韩视频不卡| 欧美视频日韩| 亚洲国产91精品在线观看| 亚洲欧美日韩人成在线播放| 亚洲欧美日韩直播| 亚洲少妇中出一区| 国产视频一区在线| 欧美视频在线播放| 欧美在线亚洲| 久久免费高清视频| 欧美在线你懂的| 欧美系列电影免费观看| 亚洲欧美成aⅴ人在线观看| 欧美视频手机在线| 夜夜嗨av一区二区三区网站四季av| 99热这里只有精品8| 韩国视频理论视频久久| 欧美区一区二区三区| 亚洲精选一区二区| 亚洲夫妻自拍| 亚洲国产精品成人综合色在线婷婷| 国产精品麻豆成人av电影艾秋| 午夜亚洲性色福利视频| 国产精品久久久久久av下载红粉| 亚洲永久免费av| 欧美尤物巨大精品爽| 亚洲社区在线观看| 日韩一区二区精品在线观看| 午夜久久影院| 欧美中文在线观看| 久久久在线视频| 久久国产精品毛片| 国产婷婷97碰碰久久人人蜜臀| 久久se精品一区二区| 亚洲国产免费看| 亚洲视频在线免费观看| 亚洲精品小视频| 99精品国产在热久久婷婷| 亚洲国产二区| 欧美不卡激情三级在线观看| 亚洲欧美一区二区精品久久久| 亚洲美女色禁图| 亚洲乱码国产乱码精品精| 国产伦精品一区二区三| 亚洲小说春色综合另类电影| 欧美成人激情视频免费观看| 国产精品久久久久一区二区| 亚洲欧美日韩国产一区| 一区二区三区免费看| 欧美精品一二三| 嫩草影视亚洲| 免费成人黄色片| 国产精品视频yy9299一区| 久久久精品2019中文字幕神马| 亚洲人成在线免费观看| 亚洲视频成人| 国内综合精品午夜久久资源| 国产精品影片在线观看| 国产精品视频自拍| 欧美激情一二区| 亚洲经典在线| 欧美+日本+国产+在线a∨观看| 黑人极品videos精品欧美裸| 亚洲欧美成人一区二区三区| 欧美风情在线观看| 国产精品久久二区| 亚洲激情一区二区三区| 欧美一区综合| 欧美日韩精品一区二区三区| 老司机精品视频一区二区三区| 欧美亚洲三级| 国产综合色精品一区二区三区| 久久亚洲电影| 欧美特黄a级高清免费大片a级| 久久人人九九| 国产视频自拍一区| 亚洲一区二区三区四区五区午夜| 亚洲精品永久免费| 韩国av一区二区三区| 久久视频在线免费观看| 久久久久久久久久码影片| 亚洲国产乱码最新视频| 在线观看日韩欧美| 国产自产女人91一区在线观看| 欧美一区二区三区男人的天堂| 国产有码在线一区二区视频| 国产日韩在线亚洲字幕中文| 国产精品日韩欧美一区二区| 狠狠狠色丁香婷婷综合久久五月| 久久久精品午夜少妇| 日韩一级网站| 中文在线资源观看网站视频免费不卡| 欧美一级一区| 亚洲电影下载| 欧美精选午夜久久久乱码6080| 免费欧美在线视频| 亚洲欧美日韩一区在线|