关于Hi3861硬件子系统&SDK适配
最近使用最新code2.0canary尝试编写外设控制程序,发现和code1.0硬件子系统适配的API不一样,具体见回帖
鸿蒙设备开发
赞
收藏 0
回答 5
已解决
相关问题
Hi3861 Hilink SDK集成
10476浏览 • 4回复 待解决
Hi3861 SDK编译出现问题
11813浏览 • 3回复 待解决
Hi3861的三个SDK区别,HiHope_WiFi-IoT_Hi3861SPC021_LiteOS_SDK 等
9942浏览 • 2回复 待解决
HI3861编译呼吸灯出错
597浏览 • 0回复 待解决
Hi3861数据保存到flash
8829浏览 • 1回复 已解决
hi3861编译失败的原因
10791浏览 • 2回复 待解决
哪里有Hi3861的芯片手册?
12775浏览 • 1回复 待解决
hi3861可以和电脑ping通,但是电脑上面的udp不能和hi3861连接
6526浏览 • 1回复 待解决
Hi3861 支持CAN通信吗
8684浏览 • 2回复 待解决
Happ现在能部署到Hi3861 么
5903浏览 • 1回复 已解决
Hi3861开发板的mesh功能
14001浏览 • 4回复 待解决
编译hispark, pegasus, hi3861, wifi 代码失败
7828浏览 • 1回复 待解决
Hi3861 WLAN模组的开发环境搭建 编译SDK时出现问题
15047浏览 • 3回复 待解决
Hi3861下使用CPP代码错误
5063浏览 • 1回复 待解决
Build Hi3861总是出现这种问题
1748浏览 • 0回复 待解决
hi3861能怎么启动OHOS的shell呢
10350浏览 • 2回复 待解决
PwmStart()参数问题(基于hi3861 HAL层实现)????
9610浏览 • 1回复 待解决
hi3861 coap_run_once函数无法识别
3892浏览 • 1回复 待解决
Hi3861 “cmsis_os2.h”查找失败
4070浏览 • 1回复 已解决
导入HI3861工程之后编译出错
5902浏览 • 2回复 待解决
hi3861开发板nfc例程出现问题
8477浏览 • 2回复 待解决
windows下载code-2.0-canary编译Hi3861 报错
7359浏览 • 3回复 待解决
hi3861三角函数无法使用问题
6417浏览 • 2回复 待解决
求指导Hi3861平台的JS应用开发???
6122浏览 • 2回复 待解决
hi3861,mqtt断开自动重连问题
8119浏览 • 1回复 待解决
1、Hi3861 SDK 接口位置
1)code1.0:vendor\hisi\hi3861\hi3861\include\
2)code2.0canary:device\hisilicon\hispark_pegasus\sdk_liteos\include\
2、code1.0 源码中适配的硬件子系统:
1)头文件:base\iot_hardware\interfaces\kits\wifiiot_lite\
2)源代码:vendor\hisi\hi3861\hi3861_adapter\hals\iot_hardware\wifiiot_lite\
3、code2.0 canary源代码适配的硬件子系统
1)头文件:base\iot_hardware\peripheral\interfaces\kits\
2)源代码:device\hisilicon\hispark_pegasus\hi3861_adapter\hals\iot_hardware\wifiiot_lite\
两个源代码版本,对应Hi3861 SDK的接口位置不同,但是API是一致的;适配的硬件子系统都在调用Hi3861 SDK 的API,但提供接口名字不一样了,现在看到硬件外设案例中都是使用code1.0适配的接口,到2.0完全对不上了。
例如设置GPIO的输入/输出:
//sdk提供的API
hi_u32 hi_gpio_set_dir(hi_gpio_idx id, hi_gpio_dir dir);
//1.0适配的实现:
unsigned int HalGpioSetDir(HalWifiIotGpioIdx id, HalWifiIotGpioDir dir)
{
return hi_gpio_set_dir((hi_gpio_idx)id, (hi_gpio_dir)dir);
}
//2.0适配的实现:
unsigned int IoTGpioSetDir(unsigned int id, IotGpioDir dir)
{
return hi_gpio_set_dir((hi_gpio_idx)id, (hi_gpio_dir)dir);
}
你这code1.0应该是指通过IDE的HPM工具下载和安装的工程吧?或者是直接下载的源码压缩包? 那些工程有些是非常久远以前的鸿蒙系统裁剪出来的,鸿蒙系统在不停地优化和调整,但是这些工程没有同步更新,所以最新的鸿蒙系统,很多子系统/组件的结构和API等,都与远古时期的代码有很大差异。
建议在LTS分支上做开发和学习轻量/小型系统,代码教新且稳定。 要学习标准系统,只能在Canary上进行了,但是该分支存在大量的不稳定现象,需要自己看着办。
如果要开发外设控制应用程序,直接使用sdk提供的API(hi_xx)应该就可以了吧?为什么还要适配硬件子系统??
我理解使用硬件子系统的接口,是为了更换硬件开发板,而外设控制应用程序不需要任何改变的,只需要开发板厂商适配好自己的SDK,给上层应用操作提供统一的接口就好了。
不知道这样理解对不对,如果是这样,硬件子系统的接口应该要保持不变吧??
现在是硬件还没有改变,源代码从1,0到2.0,外设控制程序就跑不起来了。
而且我发现2,0canary版本适配的硬件子系统并不完整,编写GPIO中断案例都不行,最近写的案例都是直接调用sdk提供的API,可能是windows对应金丝雀版本全量代码,还没更新好么?
去看一下我的文章《OpenHarmony 2.0 Canary 的 IoT硬件子系统》。
“如果要开发外设控制应用程序,直接使用sdk提供的API(hi_xx)应该就可以了吧?”
不建议这样做,鸿蒙系统的低耦合性就是通过framework层接口,把上层调用跟底层sdk的实现隔离来实现的,你直接用hi_xx接口,就跟鸿蒙的设计思想背道而驰了。
“只需要开发板厂商适配好自己的SDK” 这是对的,但是厂商要适配的接口是HalGpioSetDir/IoTGpioSetDir这一层,鸿蒙系统的这一层接口保持不变,而不是hi_gpio_set_dir这一层,hi_gpio_set_dir这一层是厂商内部自己的接口,A厂家可以是ha_gpio_set_dir,B厂家可以是hb_gpio_set_dir......