日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 嵌入式 > 嵌入式案例Show
[導讀]硬件抽象層介紹 + 硬件抽象層(Hardware Abstraction Layer,簡稱HAL)是介于android內核kernel和上層之間的抽象出來的一層結構,是對Linux驅動的一個封裝,對上層提供統(tǒng)一接口,上層應用不必知道下層硬件具體怎么工作的,屏蔽了底層的實現(xiàn)細節(jié)。為什么有了 硬


硬件抽象層介紹



+


硬件抽象層(Hardware Abstraction Layer,簡稱HAL)是介于android內核kernel和上層之間的抽象出來的一層結構,是對Linux驅動的一個封裝,對上層提供統(tǒng)一接口,上層應用不必知道下層硬件具體怎么工作的,屏蔽了底層的實現(xiàn)細節(jié)。為什么有了 硬件抽象層有其存在的意義:

1)不是所有的硬件設備都有標準的Linux內核接口,通過HAL層封裝了一套固定的向上接口,可以使得上層的開發(fā)邏輯更清晰簡單。HAL框架是固定的,開發(fā)人員只需要按照框架開發(fā)即可,無需關注與上層的交互上,將精力放在HAL層本身的實現(xiàn)上即可。

2)從商業(yè)角度,硬件廠商可以把一些核心的算法、調試參數(shù)、實現(xiàn)邏輯等放在HAL層而不是kenel層,kenel層只是簡單與硬件做數(shù)據(jù)交互。這樣的好處是可以不用遵Linux的GPL開源協(xié)議,保護自身的商業(yè)機密。

Hal架構圖


模塊類型結構體hw_module_t,設備類型結構體hw_device_t,

兩個結構體的詳細內容可以參考源碼路徑:/hardware/libhardware/include/hardware/hardware.h。HAL層開發(fā)主要工作是建立好自定義的結構體,并實現(xiàn)hw_device_t的內部的幾個關鍵函數(shù)。


  1. 頭文件hardware/libhardware/include/hardware/testled_hal.h

#ifndef _LED_HAL_H_#define _LED_HAL_H_

#include <hardware/hardware.h>

#define LED_HAL_MODULE_ID "testled_hal"

struct testled_module_t { struct hw_module_t common;};

struct testled_device_t {struct hw_device_t common; int (*open)(void); int (*control)(int on);};

#endif

頭文件內申明了led的兩個關鍵結構體testled_module_t和testled_device_t,結構體的實現(xiàn)在c文件中。


2)c文件 hardware/libhardware/modules/testled/testled_hal.c


#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <unistd.h>#include <string.h>#include <errno.h>#include <hardware/testled_hal.h>#include <linux/ioctl.h>


//日志的標簽

#define LOG_TAG "testled_hal"#include <utils/Log.h>



#define LEDCTRL_MAGIC 'k'#define LED1CTRL_ON_CMD _IO (LEDCTRL_MAGIC, 1)#define LED1CTRL_OFF_CMD _IO (LEDCTRL_MAGIC, 2)#define LED2CTRL_ON_CMD _IO (LEDCTRL_MAGIC, 3)#define LED2CTRL_OFF_CMD _IO (LEDCTRL_MAGIC, 4)

static int fd;

int testled_hal_dev_close(struct hw_device_t *device){ if(device != NULL) { struct testled_device_t *temp = (struct testled_device_t *)device; free(temp); }

close(fd);

return 0;}

int testled_hal_open_dev(void){ ALOGD("--%s--", __func__);

fd = open("/dev/test-led", O_RDWR); if(fd < 0) { ALOGE("open failed : %s", strerror(errno)); return fd; }

return 0;}

int testled_hal_control_dev(int on){ ALOGD("--%s--", __func__);

int ret;



switch(on){ case 0: ret = ioctl(fd, LED1CTRL_ON_CMD,0); break; case 1: ret = ioctl(fd, LED1CTRL_OFF_CMD,0); break; case 2: ret = ioctl(fd, LED2CTRL_ON_CMD,0); break; case 3: ret = ioctl(fd, LED2CTRL_OFF_CMD,0); break; default: break;

}


if(ret < 0){ ALOGE("control failed : %s", strerror(errno)); return ret; }

return 0;}

int testled_hal_module_open(const struct hw_module_t *module, const char *id, struct hw_device_t **device){ ALOGD("--%s--", __func__);

struct testled_device_t *led_dev = NULL;

led_dev = (struct testled_device_t *)malloc(sizeof(struct testled_device_t)); if (led_dev == NULL)     { ALOGE("malloc failed"); return -1; }

ALOGD("malloc success");

//初始化device對象 led_dev->common.tag = HARDWARE_DEVICE_TAG; led_dev->common.version = 1; led_dev->common.module = module; led_dev->common.close = testled_hal_dev_close;

led_dev->open = testled_hal_open_dev; led_dev->control = testled_hal_control_dev;


//將當前的led_dev傳遞給jni層

 *device = (struct hw_device_t *)led_dev;

return 0; }

struct testled_device_t testled_hal_methods = { open : testled_hal_module_open, };

struct testled_module_t HAL_MODULE_INFO_SYM = { common : { tag : HARDWARE_MODULE_TAG, version_major : 1, version_minor : 0, id : LED_HAL_MODULE_ID, name : "testled hal module", methods : &testled_hal_methods, },};

主要實現(xiàn)了hal結構體中的close,open,control函數(shù),并將函數(shù)傳給結led_dev構體。

led_dev->common.close = testled_hal_dev_close;

led_dev->open = testled_hal_open_dev;led_dev->control = testled_hal_control_dev;



  1. Android.mk hardware/libhardware/modules/testled/Android.mk

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE := testled_hal.defaultLOCAL_MODULE_RELATIVE_PATH := hwLOCAL_SRC_FILES := testled_hal.cLOCAL_SHARED_LIBRARIES := liblog libcutilsLOCAL_MODULE_TAGS := optional

include $(BUILD_SHARED_LIBRARY)


將c文件編譯成模塊


  1. hardware/libhardware/modules/Android.mk內加入testled



三、編譯

模塊編譯

mmm hardware/libhardware/modules/ testled

在out/target/product/nanopc-t4/system/lib/hw/ 目錄下生生成test_led_hal.default.so

全部編譯后,test_led_hal.default.so在設備的/system/lib/hw路徑下,android frameworks中的JNI調用led設備時,通過一系列轉換就會調用到這個庫內部的函數(shù),從而調動掉底層的led驅動。


掃碼關注我們

看更多嵌入式案例



喜歡本篇內容請給我們點個再看

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉