#物联网征文#【FFH】Hi3516DV300驱动开发——编写LED灯控制程序 原创 精华
Hi3516DV300驱动开发——编写LED灯控制程序
前言
概述
前面的文章只是涉及到内核态驱动程序的实现,并未涉及到用户态应用程序,以及用户态应用程序与内核态驱动程序之间的数据交互流程,在本示例将演示如何在开发板上运行一个控制LED灯的程序,达到能关闭灯、开启灯以及翻转灯的状态。希望通过本教程的学习,开发者能掌握如何开发一个设备驱动,以及如何在应用层调用驱动。
开发环境
- 硬件平台:润和AI_Camera_Hi3516DV300开发板
- 源码:OpenHarmony 3.1 release
- 环境:Windows+Ubuntu混合开发环境
- 工具:Deveco Device Tool
- 产品:ipcamera_hispark_taurus LiteOS内核OpenHarmony小型系统
参考文章
以下三篇是一些环境的准备以及流程的解析
【FFH】Hi3516DV300 OpenHarmony3.1环境配置及烧录
【FFH】DevEco Device Tool:HDF框架一键生成!
【FFH】HDF驱动开发流程解析
本次编写点亮LED灯程序参考的是BearPi-HM_Micro开发板的示例进行改写实现的在HI3516DV300上的适配。
编写点亮LED灯程序
也参考了大佬的案例代码,也给了很多启发。
示例程序:led_rgb
任务流程
点亮LED主要包含以下任务:
-
生成HDF框架
HDF框架由Deveco Device Tool自动生成,相比传统开发模式,可以省去驱动编译文件实现这一步骤,简化hcs配置文件修改以及驱动代码编写。当然,目前只支持Hi3516DV300开发板,如果不支持的话可以参考官方文档自己手动进行编写,配合参考样例代码食用更佳(参考文章已给出)。 -
LED驱动代码开发
- 编写驱动代码
- 编写驱动配置文件
- 点亮LED业务代码开发
- 编写业务代码
- 编写业务代码编译文件
一,生成HDF驱动框架
打开Deveco Device Tool插件选择HDF并选择好产品,点击+号添加驱动模块,命名为led。
二,LED驱动代码开发
- 确定目录结构
驱动代码位于drivers/framework/model/led/driver目录下,
驱动编译文件位于drivers/adapter/khdf/liteos/model/led目录下,
板级配置入口文件hdf.hcs位于vendor/hisilicon/hispark_taurus/hdf_config目录下,hcs驱动设备描述位于device_info/device_info.hcs,在hdf_config目录下新建led文件夹,并创建私有驱动配置文件led_config.hcs。
- 编写驱动代码
点击c/c++即可快速跳转到驱动代码目录文件下。
修改驱动代码如下:
- 编写驱动配置文件
3.1 修改驱动设备描述
点击hcs即可快速跳转到驱动设备描述文件下
添加驱动私有数据匹配的关键字,用于获取私有配置信息。
3.2 编写驱动私有配置信息
在vendor/hisilicon/hispark_taurus/hdf_config/led/led_config.hcs中添加LED私有配置描述。Hi3516DV300的绿色LED引脚号为19,设置led_gpio_num = 19,可以修改led_gpio_num的值来改变要操作的gpio,通过私有配置的好处是使驱动能够更好的适配各种设备以及开发板。
配置信息定义之后,需要将该配置文件添加到板级配置入口文件vendor/hisilicon/hispark_taurus/hdf_config/hdf.hcs,示例如下:
- 小结
- device_info.hcs文件中的moduleName必须要和驱动文件中的moduleName字段匹配,这样驱动才会加载起来。
- device_info.hcs文件中的deviceMatchAttr的字段必须和私有配置文件中led_config.hcs的match_attr的字段匹配,这样私有配置才能生效。
- device_info.hcs文件中的serviceName的字段需和业务代码获取服务用到的函数的serviceName参数匹配,这样用户态才能成功获取到服务。用户程序是无法直接访问驱动的,当只有驱动程序向用户态暴露server后,用户程序才能通过Dispatch的方式发送指令到驱动程序,这是用户态程序与驱动程序数据交互的关键。
三,点亮LED灯业务代码
- 确定目录结构。
开发者编写Hi3516DV300业务时,务必先在./applications/sample/camera路径下新建一个目录(或一套目录结构),用于存放业务源码文件。
例如:在app下新增业务my_led_app,其中my_led_app.c为业务代码,BUILD.gn为编译脚本,具体规划目录结构如下:
- 编写业务代码。(my_led_app.c)
- 编写将构建业务代码的BUILD.gn文件。
BUILD.gn文件由三部分内容(目标、源文件、头文件路径)构成,需由开发者完成填写。
- 首先导入 gni 组件,将源码my_led_app.c编译成led_lib库文件
- 输出的可执行文件名称由 output_name 定义为my_led
- include_dirs 里面加入my_led_app.c里面需要用到的.h的头文件路径
- deps 里面加入所依赖的库。
- 然后将led_lib打包成 lite_component,命名为my_led_app组件。
- 添加新组件
在./build/lite/components/applications.json中为application子系统添加组件my_sample,将目标和路径添加到组件配置中。
- 修改单板配置文件
在vendor/hisilicon/hispark_taurus/config.json文件中为开发板的application子系统添加组件,新增my_sample组件的条目,使样例能编译进开发板工程中。
四,运行结果
示例代码编译、烧录后,在命令行输入以下指令可控制开发板的LED灯。
关闭LED:
开启LED:
翻转LED:
从以下日志的Get reply中可以收到驱动上报的当前灯的状态,"0"表示当前灯为关闭状态,"1"表示当前灯为打开状态。
演示视频地址:
Hi3516DV300LED灯控制程序演示
【本文正在参加物联网有奖征文活动】,活动链接:https://ost.51cto.com/posts/14758
万物都从点灯开始,楼主这个点灯很有技术含量。
大佬们的花式点灯
图中的箭头都是楼主加的吗,好详细的讲解
是的哦,感谢认可(*^▽^*)
大佬和我的差距从点灯开始
讲解十分细致!