第九章------HAL

来源:http://www.cnblogs.com/didaduduhello/archive/2016/06/21/5604761.html
-Advertisement-
Play Games

HAL是建立在Linux驅動之上的的程式庫,他是一個應用層,它的作用保護內部私有。有一種是位於Android層次的系統運行庫層,Linux中只保留與寄存器相互的代碼,通過HAL進行數據的傳遞。 為Android加入HAL的主要目的是: 統一硬體的調用介面。 解決GPL版權問題。 資源等特殊要求。 這 ...


HAL是建立在Linux驅動之上的的程式庫,他是一個應用層,它的作用保護內部私有。有一種是位於Android層次的系統運行庫層,Linux中只保留與寄存器相互的代碼,通過HAL進行數據的傳遞。

為Android加入HAL的主要目的是:

統一硬體的調用介面。

解決GPL版權問題。

資源等特殊要求。

這個是新版的Android HAL架構,與原來的區別增加了新的代碼入口。他只需要用ID來定位,用Service程式庫。

 

在LED實驗中可以加入HAL,他不需要關心他們之間的交互方式,像普通的API就可以交互,將所有的邏輯從LED驅動移動到HAL模塊,而先前的LED驅動只保留讀寫寄存器的功能。

編寫一款支持HAL的Linux驅動程式的步驟:

  1. 編寫Linux驅動
  2. 編寫HAL Library
  3. 編寫Service Library

新改進了以後的LED的build.sh的腳本可以支持多個設備,處理多個設備,而不需要每一次都去關閉Android模擬器。

在測試讀寫寄存器時,因為是LED接受的不是字元串,而是位元組類型的數據,因此以位元組形式輸入在進行測試即可。

編寫調用LED驅動的HAL模塊

HAL規定不能直接使用hw_module_t結構體,因此在外部還要加一層結構體,要使用led函數指針,定義打開和關閉的指針。設置文件的句柄,控制LED開關的通用函數,根據它的開關輸出響應的日誌信息,存儲發送被設置文件或者從設備接收的數據,設置第一個位元組為讀取GPMDAT寄存器數據的狀態,讀取數據,保留有關數據。使用switch…case語句調用led;打開指定的led,led_off控制led,關閉設備函數;在初始化寄存器,打開設備為其分配記憶體空間,先清零,在設置。

總結它的原理和步驟:

  1. 定義結構體和巨集定義
  2. 編寫HAL模塊的open函數
  3. 定義he_module_methods結構體變數
  4. 定義HAL_MODULE_INFO_SYM變數
  5. 編寫HAL模塊的close函數
  6. 編寫控制LED的函數

在Android系統中使用Linux驅動有兩種方式:傳統方式直接與Linux驅動交互,例如讀取文件;還有就是HAL:本質上就是通過Linux共用庫(.so)與Linux驅動交互,然後再訪問Linux共用庫。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 按照我之前安裝5.6的安裝方法(MySQL免安裝版下載與配置)安裝5.7的時候出現問題: mysql服務無法啟動,服務沒有報任何錯誤 其實在這學期開始學習mysql的時候,就聽老師同學說,登錄不了的問題,當時沒有在意,也是因為電腦上早就安裝了mysql5.6,也就沒有在意這個問題。這兩天win10系 ...
  • 本章將講解,Sybase下如何把含逗號字元串轉化為結果集。 示例如下: 把含有逗號的字元串,拆開放入結果集。 當用到臨時表時,可以直接把臨時表當做物理表一樣使用。 over ...
  • 說說複合索引 寫索引的博客太多了,一直不想動手寫,有一下兩個原因: 一是覺得有炒剩飯的嫌疑,有兄弟曾說:索引嗎,只要在查詢條件上建索引就行了,真的可以這麼暴力嗎? 二來覺得,索引是個非常大的話題,很難概括出所有的情況,你不整齣點新意來,倒是有抄襲照搬的嫌疑 既然寫了,就寫一點稍微不一樣的東西出來, ...
  • 今天在Java學習群里看到有人問:用alert能不能修改表結構?我第一反應是,alert是彈窗啊,怎麼修改表結構?後來再看才知道,是那人打錯了!我也暈了一下,還是記一下吧!alter是修改表結構的,alert()是彈出框! —————————————————————————————————————— ...
  • 對於數據獲取,如果查詢優化器在執行計劃里選擇了索引,那麼SQL Server里的每個索引可以提高你的查詢性能。但在另一方面,每個索引也會傷及你的性能,因為在INSERT,UPDATE和DELETE期間,每個索引需要被維護。因此對於你的工作量,儘可能創建少的索引非常重要——不然在寫操作期間,你會有巨大 ...
  • 之前一直不知道在shell中調用read賦值後,怎麼傳給makefile中的變數,後來才恍然大悟。 myname := $(shell read -p "Enter your name:" name;\ echo $$name) all : @echo ${myname} ...
  • 1. 從mysql的官網下載mysql57-community-release-el6-8.noarch.rpm 2. 安裝第一步下載的rpm 3. 安裝完成之後,我們發現在/etc/yum.repos.d目錄下新增了兩個文件:其中第二文件記錄了mysql的源信息。 4. 查看可用的mysql安裝源 ...
  • 1. 查看目錄下有什麼文件/目錄 > ls //list列出目錄的文件信息 > ls -l 或ll //list -list以“詳細信息”查看目錄文件 > ls -a //list -all查看目錄“全部”(包括隱藏文件)文件 > ls -al //list -all list 查看目錄“全部”(包 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...