0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenHarmony驱动框架解读

电子发烧友开源社区 来源:OpenAtom OpenHarmony 作者:yuanbo 2021-11-06 09:23 次阅读

IoT时代下,终端设备差异较大、形态各异、尺寸各异、交互方式各异,解决设备适配问题无疑是实现万物互联的一个关键。但是,在驱动框架的开发和部署过程中,由于终端设备对硬件的计算和存储能力的需求不同、设备厂商提供的设备软硬件操作接口不同、内核提供的操作接口不同,这就使得OEM厂商部署系统的时候需要投入大量的精力来适配和维护驱动代码。

能否提供了一个跨芯片平台、跨内核的驱动框架,使得设备驱动软件可以在不同的设备上运行?OpenHarmony作为一个自主研发、全新技术生态的全领域下一代开源操作系统,提供了一套驱动框架来满足此诉求。

下面我们将带着大家解读OpenHarmony驱动框架。

一、OpenHarmony驱动框架解读 1. 设计目标

为解决在开发和部署过程中遇到的困难,OpenHarmony驱动框架设计目标如下:

  • 支持百K级~G级容量的设备部署,如手机、手环等

  • 提供统一硬件IO抽象,屏蔽SoC芯片差异,兼容不同内核,如LinuxLiteOS等。

  • 屏蔽驱动和系统组件间交互。可动态拆解,满足不同容量设备的部署。

  • 面向不同容量的设备,提供统一的配置界面。

2. 设计思路

OpenHarmony驱动框架(下面简称为HDF)通过提供驱动与芯片平台、内核解耦的底座,规范硬件驱动接口,实现驱动软件在不同设备中部署。

HDF驱动框架架构如下图所示。

988caab8-3e41-11ec-82a9-dac502259ad0.png

1 驱动架构

为了达成设计目标,OpenHarmony驱动框架采用如下核心设计思路:

(1)弹性化架构
  • 框架可动态伸缩:通过对象管理器,多态加载不同容量设备实现方式,实现弹性伸缩部署。
  • 驱动可动态伸缩:支持统一的设备驱动插件管理,实现设备驱动任意分层,积木式组合拼接

(2)组件化设备模型

  • 提供设备功能模型抽象,屏蔽设备驱动与系统交互的实现,为开发者提供统一的驱动开发接口
  • 提供主流IC的公版驱动能力,支持配置化部署

(3)归一化平台底座

提供规范化的内核、SoC硬件IO适配接口,兼容不同内核、SoC芯片,对外开发规范化的平台驱动接口

(4)统一配置界面

构建全新的配置语言,面向不同容量的设备,提供统一配置界面,支持硬件资源配置和设备信息配置

3. 构建策略

面向Liteos的轻量级设备,主要基于HDF构建主流IC驱动,形成公版驱动和通用设备功能模型,支撑不同硬件芯片、不同内核(LiteOS-M/LiteOS-A)部署。98ea93ee-3e41-11ec-82a9-dac502259ad0.png

2 轻量级设备部署模式

面向标准设备,除了支持内核态驱动,还支持用户态驱动。用户态驱动的重点在于构建设备抽象模型,为系统提供统一的设备接口,兼容Linux原生驱动和HDF驱动。内核态则使用Linux驱动与HDF驱动并存的策略,提供端到端的解决方案。

994f368c-3e41-11ec-82a9-dac502259ad0.png

3 标准设备部署模式

4. 现状与演进

目前HDF驱动框架已经支持Liteos-m、Liteos-a、Linux内核,以及OpenHarmony轻量级、标准级上部署,并且在标准系统上同时支持内核态与用户态部署。

经过开发者的不断努力,OpenHarmony驱动框架正在不断完善和增强,在OpenHarmony LTS3.0中,基础框架新增了对热插拔设备的管理以及HDI编译工具hdi-gen,驱动模型部分新增了Audio、Camera、Senso、USB DDK等多个模块的支持。

二、OpenHarmony驱动开发 OpenHarmony驱动为了避免与具体内核产生依赖,实现可迁移目标,开发时需要遵循以下约定:
  • 系统相关接口使用HDF OSAL接口;
  • 总线和硬件资源相关接口使用平台驱动提供的相关接口。

基于HDF框架,驱动开发的通常流程包含驱动代码的实现、编译脚本、配置文件添加、以及用户态程序和驱动交互的流程。下面将详细介绍HDF驱动开发一般步骤。

1. 实现驱动代码

在HDF驱动框架中,HdfDriverEntry对象被用来描述一个驱动实现。
structHdfDriverEntry{int32_tmoduleVersion;constchar*moduleName;int32_t(*Bind)(structHdfDeviceObject*deviceObject);int32_t(*Init)(structHdfDeviceObject*deviceObject);void(*Release)(structHdfDeviceObject*deviceObject);};

编写一个简单的驱动,首先需要实现驱动程序(Driver Entry)入口中的三个主要接口:

  • Bind接口:实现驱动接口实例化绑定,如果需要发布驱动接口,会在驱动加载过程中被调用,实例化该接口的驱动服务并和DeviceObject绑定。当用户态发起调用时,Bind中绑定的服务对象的Dispatch方法将被回调,在该方法中处理用户态调用的消息。
  • Init接口:实现驱动或者硬件的初始化,返回错误将中止驱动加载流程。

  • Release接口:实现驱动的卸载,在该接口中释放驱动实例的软硬件资源。

一个基于HDF框架编写的简单驱动代码如下,其功能是用户态消息回环,即驱动收到用户态发送的消息后将相同内容的消息再发送给用户态:

#include"hdf_base.h"#include"hdf_device_desc.h"#include"hdf_log.h"#defineHDF_LOG_TAG"sample_driver"#defineSAMPLE_WRITE_READ0xFF00static int EchoString(struct HdfDeviceObject *deviceObject, struct HdfSBuf *data, struct HdfSBuf *reply){constchar*readData=HdfSbufReadString(data);if(readData==NULL){HDF_LOGE("%s:failedtoreaddata",__func__);returnHDF_ERR_INVALID_PARAM;}if(!HdfSbufWriteInt32(reply,INT32_MAX)){HDF_LOGE("%s:failedtoreplyint32",__func__);returnHDF_FAILURE;}returnHdfDeviceSendEvent(deviceObject,id,data);//发送事件到用户态}int32_tHdfSampleDriverDispatch(structHdfDeviceObject*deviceObject,intid,structHdfSBuf*data,structHdfSBuf*reply){constchar*readData=NULL;intret=HDF_SUCCESS;switch(id){switchSAMPLE_WRITE_READ:ret=EchoString(deviceObject,data,reply);break;default:HDF_LOGE("%s:unsupportedcommand");ret=HDF_ERR_INVALID_PARAM;}returnret;}void HdfSampleDriverRelease(struct HdfDeviceObject *deviceObject){//在这里释放驱动申请的软硬件资源return;}int HdfSampleDriverBind(struct HdfDeviceObject *deviceObject){if(deviceObject==NULL){returnHDF_FAILURE}staticstructIDeviceIoServicetestService={.Dispatch=HdfSampleDriverDispatch,};deviceObject->service=&testService;returnHDF_SUCCESS;}int HdfSampleDriverInit(struct HdfDeviceObject *deviceObject){if(deviceObject==NULL){HDF_LOGE("%s::ptrisnull!",__func__);returnHDF_FAILURE;}HDF_LOGE("SampledriverInitsuccess");returnHDF_SUCCESS;}structHdfDriverEntryg_sampleDriverEntry={.moduleVersion=1,.moduleName="sample_driver",.Bind=HdfSampleDriverBind,.Init=HdfSampleDriverInit,.Release=HdfSampleDriverRelease,};HDF_INIT(g_sampleDriverEntry);

2. 配置设备信息

在HDF框架的配置文件(例如vendor/hisilicon/xxx/config/device_info.hcs)中添加该驱动的配置信息,配置目录与具体开发板关联,如下所示:
root{device_info{match_attr="hdf_manager";templatehost{hostName="";priority=100;templatedevice{templatedeviceNode{policy=0;priority=100;preload=0;permission=0664;moduleName="";serviceName="";deviceMatchAttr="";}}}sample_host::host{hostName="host0";//host名称,host节点是用来存放某一类驱动的容器priority=100;//host启动优先级(0-200),值越大优先级越低,建议默认配100,优先级相同则不保证host的加载顺序device_sample::device{//sample设备节点device0::deviceNode{//sample驱动的DeviceNode节点policy=1;//policy字段是驱动服务发布的策略,在驱动服务管理章节有详细介绍priority=100;//驱动启动优先级(0-200),值越大优先级越低,建议默认配100,优先级相同则不保证device的加载顺序preload=0;//驱动加载策略,参考《5.2HDF驱动框架章节》permission=0664;//驱动创建设备节点权限moduleName="sample_driver";//驱动名称,该字段的值必须和驱动入口结构体的moduleName值一致serviceName="sample_service";//驱动对外发布服务的名称,必须唯一deviceMatchAttr="sample_config";//驱动私有数据匹配的关键字,必须和驱动私有数据配置表中的match_attr值相等}}}}}

(左右滑动,查看更多)

定义设备列表时使用了HCS的模板语法,template host节点下的内容由HDF框架定义,新增host以及host中的device只需要继承该模板并填充具体内容即可。

在配置中定义的device将在加载过程中产生一个设备实例,配置中通过moduleName字段指定设备对应的驱动名称,从而将设备与驱动关联起来。其中,设备与驱动可以是一对多的关系,即可以实现一个驱动支持多个同类型设备。

3. 用户态程序与驱动交互

用户态程序和驱动交互基于HDF IoService模型实现,该设计屏蔽了具体内核的差异,将驱动接口抽象为IoService对象,调用者基于名称获取该对象,并可以使用IoService系列接口进行接口调用和事件监听。值得一提的是消息传递时使用了HDF Sbuf对象进行参数的序列化和反序列化,这样可以避免不受控的内存访问,也简化了消息传递和分发过程中的内存所有权问题,有利于提升用户态和内核态数据传递的安全性和便利性。HDF Sbuf相关接口可以参考HarmonyOS设备开发官网API Reference中头文件hdf_sbuf.h部分。

基于HDF框架编写的用户态程序和驱动交互的代码如下:

#include"hdf_log.h"#include"hdf_sbuf.h"#include"hdf_io_service_if.h"#defineHDF_LOG_TAG"sample_test"#defineSAMPLE_SERVICE_NAME"sample_service"#defineSAMPLE_WRITE_READ0xFF00intg_replyFlag=0;static int OnDevEventReceived(void *priv, uint32_t id, struct HdfSBuf *data){constchar*string=HdfSbufReadString(data);intret=HDF_SUCCESS;if(string==NULL){HDF_LOGE("failedtoreadstringineventdata");ret=HDF_FAILURE;}else{HDF_LOGE("%s",string);}g_replyFlag=1;returnret;}static int SendEvent(struct HdfIoService *serv, char *eventData){intret=0;structHdfSBuf*data=HdfSBufObtainDefaultSize();//申请需要发送的序列化对象if(data==NULL){HDF_LOGE("failedtoobtainsbufdata");return1;}structHdfSBuf*reply=HdfSBufObtainDefaultSize();//申请返回数据的序列化对象if(reply==NULL){HDF_LOGE("failedtoobtainsbufreply");ret=HDF_DEV_ERR_NO_MEMORY;gotoout;}if(!HdfSbufWriteString(data,eventData)){//准备消息内容HDF_LOGE("failedtowritesbuf");ret=HDF_FAILURE;gotoout;}ret=serv->dispatcher->Dispatch(&serv->object,SAMPLE_WRITE_READ,data,reply);//发起接口调用if(ret!=HDF_SUCCESS){HDF_LOGE("failedtosendservicecall");gotoout;}intreplyData=0;if(!HdfSbufReadInt32(reply,&replyData)){//反序列化返回数据HDF_LOGE("failedtogetservicecallreply");ret=HDF_ERR_INVALID_OBJECT;gotoout;}HDF_LOGE("Getreplyis:%d",replyData);out:HdfSBufRecycle(data);HdfSBufRecycle(reply);returnret;}int main(){structHdfIoService*serv=HdfIoServiceBind(SAMPLE_SERVICE_NAME);//通过名称获取IoService对象,与驱动配置中的名称一致if(serv==NULL){HDF_LOGE("failedtogetservice%s",SAMPLE_SERVICE_NAME);returnHDF_FAILURE;}staticstructHdfDevEventlistenerlistener={//构造驱动事件监听器对象.callBack=OnDevEventReceived,//填充事件处理方法.priv=NULL;};if(HdfDeviceRegisterEventListener(serv,&listener)!=HDF_SUCCESS){//注册事件监听HDF_LOGE("failedtoregistereventlistener");returnHDF_FAILURE;}if(SendEvent(serv,"HelloWorld,HDFDriver!")){//调用驱动接口,样例驱动收到事件HDF_LOGE("failedtosendevent");returnHDF_FAILURE;}while(g_replyFlag==0){//等待驱动上报事件sleep(1);}HdfDeviceUnregisterEventListener(serv,&listener));//去注册事件监听器HdfIoServiceRecycle(serv);//回收IoService对象return0;}

(左右滑动,查看更多)

该示例执行后会在终端中打印出"Hello World, HDF Driver!"字符串,表明我们的用户态测试程序和驱动成功地进行了一次交互。

三、使用DevEco Device Tool进行驱动开发

上一小节介绍了OpenHarmony驱动的一般开发方法,那么有没有更简单的方法添加一款驱动呢?答案就是华为南向开发IDE——DevEco Device Tool。DevEco Device Tool最新版本已经集成了HDF驱动开发功能,下面介绍如何使用DevEco Device Tool进行驱动开发。

DevEco Device Tool下载链接:https://device.harmonyos.com/cn/develop/ide#download_release

1. 创建驱动

(1)导入工程

参考DevEco Device Tool手册,通过npm或网络下载的方式导入OHOS工程。

(2)使用HDF页面工具创建新驱动,按照需求填写Module名称,工具将根据Module名称创建对应驱动代码与。

DevEco Device Tool将自动生成驱动实现代码:

9b2055f4-3e41-11ec-82a9-dac502259ad0.png

7 Device Eco Tool 生成驱动代码

为源码文件自动生成编译脚本:

9b9fadf4-3e41-11ec-82a9-dac502259ad0.png

8 Device Eco Tool 生成驱动编译脚本

DevEco Device Tool还会在对应单板的驱动配置中生成驱动设备配置信息:

9bfb783c-3e41-11ec-82a9-dac502259ad0.png

9 Device Eco Tool 生成驱动配置信息

2. 修改驱动

DevEco Device Tool提供了快捷方式直达源码、编译脚本、配置文件,点击链接修改相关文件,实现驱动功能。DevEco Device Tool自动生成代码已经提供了DriverEntry的基础实现,只需填充对应函数的实际功能即可。

3. 编译版本

使用DevEco Device Tool build功能一键编译版本,编译输出显示在终端窗口:9cb753ea-3e41-11ec-82a9-dac502259ad0.png

11 Device Eco Tool编译界面

4. 烧录验证

DevEco Device Tool提供了一站式的烧录、调试环境。使用upload功能将编译好的镜像烧录进开发板。9d136d6a-3e41-11ec-82a9-dac502259ad0.png

12 Device Eco Tool烧写功能界面

烧录过程和进度显示在终端窗口

9d6ac830-3e41-11ec-82a9-dac502259ad0.png

图13 Device Eco Tool烧写输出

四、总结

除了在此次HDC大会与大家分享驱动框架的设计和最新进展,开放原子基金会还在OpenHarmony公众号、gitee社区等渠道发布了一系列技术分享、指导文档等资料,欢迎大家关注并一起建设OpenHarmony驱动生态。

责任编辑:haq
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    450

    文章

    49614

    浏览量

    417067
  • 驱动
    +关注

    关注

    12

    文章

    1787

    浏览量

    84893
  • 鸿蒙系统
    +关注

    关注

    183

    文章

    2627

    浏览量

    65779
  • HarmonyOS
    +关注

    关注

    79

    文章

    1946

    浏览量

    29732
  • OpenHarmony
    +关注

    关注

    25

    文章

    3545

    浏览量

    15730

原文标题:HDC2021技术分论坛:OpenHarmony驱动框架解读和开发实践

文章出处:【微信号:HarmonyOS_Community,微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    OpenHarmony开发者大会2024:诚迈科技多项荣誉加冕再证实力

    5月25日,OpenHarmony开发者大会2024在深圳成功举办。大会以OpenHarmony 4.1 Release版本根技术特性解读为契机,聚焦技术革新和社区生态进展
    的头像 发表于 05-27 18:14 657次阅读
    <b class='flag-5'>OpenHarmony</b>开发者大会2024:诚迈科技多项荣誉加冕再证实力

    OpenHarmony4.0源码解析之媒体框架

    及 audio-source 插件调用音频框架的播放及采集功能来实现音频的播放与录制;通过 surface-sink 调用图形框架,video-decoder 调用解码驱动
    的头像 发表于 02-26 22:05 557次阅读
    <b class='flag-5'>OpenHarmony</b>4.0源码解析之媒体<b class='flag-5'>框架</b>

    OpenHarmony 之 NAPI 框架介绍

    环境中的 JS 变量与方法。 OpenHarmony 中的 NAPI OpenAtom OpenHarmony(以下简称 “OpenHarmony”)应用层基于 javascript 语言开发,而系统
    的头像 发表于 02-01 17:34 538次阅读
    <b class='flag-5'>OpenHarmony</b> 之 NAPI <b class='flag-5'>框架</b>介绍

    教程分享!OpenHarmony之NAPI框架介绍

    是 C++语言实现的,这些接口可以帮助 C++代码创建 JS 变量,或访问 JavaScript 运行环境中的 JS 变量与方法。 OpenHarmony 中的 NAPI OpenAtom OpenHarmony(以下简称“OpenHa
    的头像 发表于 11-30 12:15 1149次阅读
    教程分享!<b class='flag-5'>OpenHarmony</b>之NAPI<b class='flag-5'>框架</b>介绍

    OpenHarmony Meetup 2023北京站圆满举办

    meetup线下交流形式,解读OpenHarmony作为下一代智能终端操作系统的新版本及成果转化,提升开发者对OpenHarmony的关注度,普及OpenHarmony开发技能,加速开
    的头像 发表于 11-28 21:10 519次阅读
    <b class='flag-5'>OpenHarmony</b> Meetup 2023北京站圆满举办

    上海站报名启动! 2023年开源产业生态大会OpenHarmony生态分论坛

    ,目标是面向全场景、全连接、全智能时代、基于开源的方式,搭建一个智能终端设备操作系统的框架和平台,促进万物互联产业的繁荣发展。 开源三年以来,OpenHarmony已成为智能终端领域发展速度最快的开源
    发表于 11-24 14:55

    OpenHarmony之NAPI框架介绍

    的 NAPI OpenAtom OpenHarmony(以下简称“OpenHarmony”)应用层基于 javascript 语言开发,而系统框架层则基于 C++语言。它们之间需要一个桥梁来实现两种语言代码之间
    发表于 11-23 15:36

    OpenHarmony技术大会 | 编程语言及开发框架分论坛嘉宾金句

    点击蓝字 ╳ 关注我们 开源项目 OpenHarmony 是每个人的 OpenHarmony 原文标题:OpenHarmony技术大会 | 编程语言及开发框架分论坛嘉宾金句 文章出处:
    的头像 发表于 11-11 21:15 467次阅读

    【开源三方库】Easyui:基于OpenAtom OpenHarmony ArkUI深度定制的组件框架

    量、可靠的移动端组件库,它是对OpenAtom OpenHarmony(以下简称“OpenHarmony”) ArkUI进行深度定制的组件框架。Easyui可扩展性较强,可以基于源码进行二次开发,修改
    的头像 发表于 11-09 10:55 574次阅读
    【开源三方库】Easyui:基于OpenAtom <b class='flag-5'>OpenHarmony</b> ArkUI深度定制的组件<b class='flag-5'>框架</b>

    议程直击 | 第二届OpenHarmony技术大会——编程语言及开发框架分论坛

    点击蓝字 ╳ 关注我们 开源项目 OpenHarmony 是每个人的 OpenHarmony 原文标题:议程直击 | 第二届OpenHarmony技术大会——编程语言及开发框架分论坛
    的头像 发表于 11-01 16:10 322次阅读
    议程直击 | 第二届<b class='flag-5'>OpenHarmony</b>技术大会——编程语言及开发<b class='flag-5'>框架</b>分论坛

    OpenHarmony Meetup 2023成都站圆满举办

    meetup线下交流形式,解读OpenHarmony作为下一代智能终端操作系统的新版本及成果转化,提升开发者对OpenHarmony的关注度,普及OpenHarmony开发技能,加速开
    的头像 发表于 10-28 16:20 433次阅读
    <b class='flag-5'>OpenHarmony</b> Meetup 2023成都站圆满举办

    开鸿智谷亮相OpenHarmony Meetup深圳站!

    开源项目OpenHarmony是每个人的OpenHarmonyOpenHarmony正当时”OpenHarmonyMeetup2023城市巡回活动,旨在通过meetup线下交流形式,
    的头像 发表于 10-18 08:30 559次阅读
    开鸿智谷亮相<b class='flag-5'>OpenHarmony</b> Meetup深圳站!

    OpenHarmony Meetup 2023深圳站圆满举办

    meetup线下交流形式,解读OpenHarmony作为下一代智能终端操作系统的新版本及成果转化,提升开发者对OpenHarmony的关注度,普及OpenHarmony开发技能,加速开
    的头像 发表于 10-17 03:25 412次阅读

    直播预告 | 【OpenHarmony竞赛训练营】线上赋能直播第2期——三方库赛题解读

    OpenHarmony竞赛训练营】线上赋能直播第2期来了! 本期主题:OpenHarmony竞赛训练营三方库赛题解读 主讲嘉宾:马迪欣 时间:2023年10月9日 1500 Competition
    的头像 发表于 10-10 10:26 360次阅读
    直播预告 | 【<b class='flag-5'>OpenHarmony</b>竞赛训练营】线上赋能直播第2期——三方库赛题<b class='flag-5'>解读</b>

    OpenHarmony Meetup 2023常州站圆满举办

    meetup线下交流形式,解读OpenHarmony作为下一代智能终端操作系统的新版本及成果转化,提升开发者对OpenHarmony的关注度,普及OpenHarmony开发技能,加速开
    的头像 发表于 09-27 21:10 414次阅读