news 2026/5/14 18:52:11

传统 Hal 开发笔记4----实现 Hal 模块

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
传统 Hal 开发笔记4----实现 Hal 模块

目录

  • 一、代码编写
  • 二、编译系统配置
实现 Hal 模块

一、代码编写

接下来就来为上节实现的驱动写一个简单的 HAL 模块。

hardware/libhardware/include/hardware目录下添加hello_hal.h

#ifndef_HARDWARE_HELLO_HAL_H#define_HARDWARE_HELLO_HAL_H#include<hardware/hardware.h>__BEGIN_DECLS#defineHELLO_HAL_API_VERSIONHARDWARE_MODULE_API_VERSION(1,0)#defineHELLO_HAL_HARDWARE_MODULE_ID"hello_hal"#defineHELLO_HAL_DEVICE_ID_MAIN"main_hello_hal"structhello_hal_device_t;typedefstructhello_hal_device_t{structhw_device_tcommon;intfd;// 存储/dev/hello的文件描int(*hello_hal_open)(structhello_hal_device_t*hello_hal_dev);int(*hello_hal_read)(structhello_hal_device_t*hello_hal_dev,char*str);int(*hello_hal_write)(structhello_hal_device_t*hello_hal_dev,constchar*str);}hello_hal_device_t;staticinlineinthello_hal_methods_open(conststructhw_module_t*module,hello_hal_device_t**device){returnmodule->methods->open(module,HELLO_HAL_DEVICE_ID_MAIN,(structhw_device_t**)device);}__END_DECLS#endif// _HARDWARE_HELLO_HAL_H

这里的核心是:

  • 实现一个hello_hal_device_t结构体,这个结构体用于操作具体的硬件
  • 实现hello_hal_methods_open函数,这个函数用于从hw_module_t中找到hello_hal_device_t结构体实例
    接着在hardware/libhardware/modules/目录下添加hello_hal目录,并在hello_hal目录下添加源码文件hello_hal.c
#include<hardware/hello_hal.h>#include<hardware/hardware.h>#include<cutils/log.h>#include<malloc.h>#include<stdio.h>#include<unistd.h>#include<fcntl.h>#include<errno.h>#include<string.h>inthello_open(structhello_hal_device_t*hello_hal_dev __unused){// 打开/dev/hello,fd存入设备结构体hello_hal_dev->fd=open("/dev/hello",O_RDWR);if(hello_hal_dev->fd==-1){ALOGE("hello_hal: can not open file /dev/hello, errno=%d",errno);// 用ALOGE打印日志return-1;}return0;}inthello_close(structhw_device_t*dev){hello_hal_device_t*hello_hal_dev=(hello_hal_device_t*)dev;if(hello_hal_dev->fd>=0){close(hello_hal_dev->fd);// 关闭结构体中的fd}free(hello_hal_dev);// 释放设备结构体内存return0;}inthello_read(structhello_hal_device_t*hello_hal_dev __unused,char*str){charbuf[1024]={0};// 初始化缓冲区,避免脏数据intlen=read(hello_hal_dev->fd,buf,sizeof(buf)-1);if(len>0){buf[len]='\0';strcpy(str,buf);returnlen;}elseif(len==0){ALOGW("hello_hal: read 0 bytes from /dev/hello");return0;}else{ALOGE("hello_hal: read failed, errno=%d",errno);return-1;}}inthello_write(structhello_hal_device_t*hello_hal_dev __unused,constchar*str){if(!str){// 空指针校验ALOGE("hello_hal: write str is NULL");return-EINVAL;}intlen=strlen(str)+1;len=len<1024?len:1024;intret=write(hello_hal_dev->fd,str,len);if(ret<0){ALOGE("hello_hal: write failed, errno=%d",errno);return-1;}returnret;}// HAL模块的open函数(创建设备实例)staticinthello_hal_open(consthw_module_t*module,constchar*id __unused,hw_device_t**device){// 分配设备结构体内存(calloc自动初始化0)hello_hal_device_t*hello_hal_dev=calloc(1,sizeof(hello_hal_device_t));if(!hello_hal_dev){ALOGE("hello_hal: Can not allocate memory for hello hal device");return-ENOMEM;}// 初始化hw_device_t(HAL框架要求)hello_hal_dev->common.tag=HARDWARE_DEVICE_TAG;hello_hal_dev->common.module=(hw_module_t*)module;hello_hal_dev->common.version=HARDWARE_DEVICE_API_VERSION(1,0);hello_hal_dev->common.close=hello_close;// 现在类型匹配// 绑定自定义函数指针hello_hal_dev->hello_hal_open=hello_open;hello_hal_dev->hello_hal_write=hello_write;hello_hal_dev->hello_hal_read=hello_read;// 输出设备指针给上层*device=(hw_device_t*)hello_hal_dev;return0;}// HAL模块方法结构体staticstructhw_module_methods_thello_hal_module_methods={.open=hello_hal_open,};// HAL模块入口(必须命名为HAL_MODULE_INFO_SYM)structhw_module_tHAL_MODULE_INFO_SYM={.tag=HARDWARE_MODULE_TAG,.module_api_version=HELLO_HAL_API_VERSION,.hal_api_version=HARDWARE_HAL_API_VERSION,.id=HELLO_HAL_HARDWARE_MODULE_ID,.name="Default Hello HAL",.author="sixian",.methods=&hello_hal_module_methods,};
  • 声明一个hw_module_t结构体实例
  • 声明一个hw_module_methods_t结构体实例,其中open函数指针指向hello_hal_open
  • hello_hal_open> 会构建一个hello_hal_device_t结构体实例,对其成员赋值,核心的成员主要是hello_hal_open 、hello_hal_write、 hello_hal_read三个函数指针

二、编译系统配置

接着在hardware/libhardware/modules/hello_hal目录下添加 Android.mk

LOCAL_PATH:=$(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE:=hello_hal.default#HAL module implementation stored in#hw/<VIBRATOR_HARDWARE_MODULE_ID>.default.soLOCAL_MODULE_RELATIVE_PATH:=hw LOCAL_C_INCLUDES:=hardware/libhardware LOCAL_SRC_FILES:=hello_hal.c LOCAL_SHARED_LIBRARIES:=liblog LOCAL_MODULE_TAGS:=optional include $(BUILD_SHARED_LIBRARY)

接着在hardware/libhardware/modules/Android.mk中添加hello_hal,这样编译系统才会去编译hello_hal模块。

hardware_modules:=\ camera \ gralloc \ sensors \ hello_hal include $(call all-named-subdir-makefiles,$(hardware_modules))

接着在 product 配置文件device/xxxx/xxxx/device.mk中添加hello_hal.defaultso库:

PRODUCT_PACKAGES:=\ audio.primary.goldfish \ vibrator.goldfish \ hello_hal.default\

至此,hal 层任务完工

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/14 15:20:19

VideoSrt视频字幕生成工具:3大场景化解决方案彻底告别手动打字幕

VideoSrt视频字幕生成工具&#xff1a;3大场景化解决方案彻底告别手动打字幕 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows 你是否曾…

作者头像 李华
网站建设 2026/5/3 0:19:03

Velero API开发终极指南:从入门到精通

为什么选择Velero API&#xff1f; 【免费下载链接】velero Backup and migrate Kubernetes applications and their persistent volumes 项目地址: https://gitcode.com/GitHub_Trending/ve/velero 在当今云原生时代&#xff0c;Kubernetes已成为容器编排的事实标准。然…

作者头像 李华
网站建设 2026/5/14 4:23:57

Java线程安全:披萨争夺战的终极解法

哈哈&#xff0c;小白你好&#xff01;今天咱们来聊聊Java里的“线程安全”——这玩意儿就像一群程序员在办公室里抢同一份披萨&#xff0c;如果没点规矩&#xff0c;最后可能谁都吃不上完整的&#xff0c;还弄一地碎屑&#xff01;&#x1f604;简单说&#xff0c;线程安全就是…

作者头像 李华
网站建设 2026/5/12 2:58:21

Paperzz AI 期刊论文:从 “选题模糊” 到 “适配刊文框架”,学术新人如何高效搭建期刊级论文的写作路径

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 期刊论文https://www.paperzz.cc/journalArticle 对学术新人而言&#xff0c;期刊论文写作的门槛远高于课程论文 —— 既要贴合期刊的 “选题方向”&#xff0c;又要符合 “摘要 - 引言 - 实证…

作者头像 李华
网站建设 2026/5/12 12:49:47

期刊论文写作的“AI工具链革命”:9大智能引擎全景拆解——一场从“孤岛式写作”到“协同式科研交付”的认知升维实验

开篇&#xff1a;一场真实的“学术压力测试” 2025年12月&#xff0c;某高校青年教师接到期刊返修意见&#xff1a;“理论贡献不清晰&#xff0c;方法描述模糊&#xff0c;图表可读性弱。”距离截止日仅剩72小时。 他没有熬夜改稿&#xff0c;而是打开9款AI工具&#xff0c;构…

作者头像 李华
网站建设 2026/5/13 1:54:54

8、Linux进程管理与权限控制全解析

Linux进程管理与权限控制全解析 1. Linux权限管理基础 Linux通过权限设置来保护用户或用户组的文件和目录,防止未经授权的访问。了解这一系统不仅有助于保护文件,还能执行新的工具和文件。在某些情况下,攻击者可能会利用SUID和SGID权限,将普通用户的权限提升为root用户权…

作者头像 李华