OpenHarmony设备开发之路【01】-helloword

简介: OpenHarmony设备开发

今天我们用3861的板子来实现最简单的helloword,自此也打开我的设备开发之路。

接下来我将详细的写一下,帮助大家更好的入门

我们保证现在自己的环境都是合适的

第一步,确定目录结构

开发者编写业务时,务必先在./applications/sample/wifi-iot/app路径下新建一个目录(或一套目录结构),用于存放业务源码文件。

例如:在app下新建jianguo_hello文件夹,其中hello.c为业务代码,BUILD.gn为编译脚本,具体规划目录结构如下:

jianguo_hello$ tree
.
├── BUILD.gn
└── hello.c

0 directories, 2 files

第二步,编写业务代码

新建./applications/sample/wifi-iot/app/jianguo_hello下的hello.c文件,在hello.c中新建业务入口函数my_app,并实现业务逻辑。并在代码最下方,使用OpenHarmony启动恢复模块接口SYS_RUN()启动业务。(SYS_RUN定义在ohos_init.h文件中)

路径openharmony/applications/sample/wifi-iot/app/jianguo_hello/hello.c

#include <stdio.h>
#include "ohos_init.h"
#include "ohos_types.h"

void HelloWorld(void)
{
    printf("___________>>>>>>>>>>>>>>>>>>>> [DEMO] Hello world.\n");
}
SYS_RUN(HelloWorld);

路径openharmony/applications/sample/wifi-iot/app/jianguo_hello/BUILD.gn

# 静态库名称是什么
static_library("my_app") {
    #那些文件会被编译
    sources = [
        "hello.c",
    ]
#头文件去哪里找
    include_dirs = [
        "//utils/native/lite/include",
        "//kernel/liteos_m/kal/cmsis",
        "//base/iot_hardware/peripheral/interfaces/kits",
    ]
}

路径/openharmony/applications/sample/wifi-iot/app/BUILD.gn

BUILD.gn


import("//build/lite/config/component/lite_component.gni")

lite_component("app") {
    # 那些文件会被编译,连接的是哪个静态库
  features = [ "jianguo_hello:my_app" ]
}

image-20220917224346451

编写完代码,我们来编译一下

第三步,编译

首先运行

hb set

选择如图所示的编译环境

image-20220918150911429

然后

hb build -f

这个时候编译成功,

image-20220917230841042

编译成功

最后终端会显示编译成功,我们可以在out相应的目录下找到对应的固件

out/hispark_pegasus/wifiiot_hispark_pegasus/Hi3861_wifiiot_app_allinone.bin

image-20220918151031581

我们选择下载,下载到本地,记住路径,下文要用到

image-20220918151306314

第四步,烧录

此时将开发板通过USB接口连接在电脑,有的电脑可能需要安装驱动,如何安装驱动,我会在下一篇文章给出

image-20220917231318436

打开Hiburn软件

Hiburn软件操作演示:

然后在Hiburn软件(HiBurn软件本文档随附)上选择”Setting”,设置串口的波特率为921600(波特率影响数据收发的速度,高波特率能加快固件烧录过程,提高调试效率):

image-20220918151223533

设置完成之后,回到软件首页面,选择”SelectFile”,在弹出的文件浏览器上选择刚刚导出的固件:

点击Auto burn复选框,然后点击Connect,如下图所示

image-20220918151409420

手动按一下开发板RESET按键(在usb插孔旁边),开始下载程序。

待烧录完成之后,需要先点击disconnect断开连接。

烧录步骤完成之后,可以再次按下复位按钮启动程序.

查看控制台的输出,这里我用的sscom串口调试工具,我也会给大家给出。

image-20220918150744754

可以看到正常显示。

至此已完成了OpenHarmony固件烧录到润和3861开发板并输出helloword的操作

我的设备开发之路也就开始了。

完结,撒花

感谢各位大佬的指导

参考资料:

HiHope IOT物联网设备

润和满天星系列Pegasus智能家居OpenHarmony开发套件资料汇总

相关文章
|
10月前
|
XML 数据管理 Linux
麒麟系统开发笔记(十二):在国产麒麟系统上编译GDAL库、搭建基础开发环境和基础Demo
麒麟系统上做全球北斗定位终端开发,北斗GPS发过来的是大地坐标,应用需要的是经纬度坐标,所以需要转换,可以使用公式转换,但是之前涉及到了山He智能一个项目使用WG。
|
26天前
|
IDE 测试技术 开发工具
<HarmonyOS第一课>运行Hello World
<HarmonyOS第一课>运行Hello World
30 0
|
4月前
|
存储 前端开发 IDE
【华为鸿蒙系统学习】- 如何利用鸿蒙系统进行App项目开发|自学篇
【华为鸿蒙系统学习】- 如何利用鸿蒙系统进行App项目开发|自学篇
105 0
|
缓存 中间件 Swift
优酷iOS工程插件化 -- 大量模块壳工程本地如何快速编译
业务快速发展,优酷工程已有大量模块,模块耦合严重且混乱,模块依赖是一颗“树”,甚至于一张“网” ,导致开发体验持续严重下降,如何解决本地调试效率低、不支持模拟器、模块整包依赖不一致等等痛点问题,文中进行了说明。
53978 6
|
前端开发 Shell 测试技术
【芯片前端】以vcs编译环境为例做一个适用于芯片前端的极简版Makefile实操教程
【芯片前端】以vcs编译环境为例做一个适用于芯片前端的极简版Makefile实操教程
695 0
|
传感器 API 调度
openHarmony系统简介
今天带大家了解一下openHarmony系统,很多人可能听说过Harmony OS,今天要介绍的openHarmony系统就是Harmony OS的抽象,即基础版的,鸿蒙系统最终要实现的就是脱离安卓系统成为一个独立的系统,目前的环境使得鸿蒙系统仍然需要兼容安卓,故openHarmony诞生了,为了更好的进行过渡,同时也为更好的宣传鸿蒙系统。
629 0
openHarmony系统简介
|
前端开发 JavaScript API
openHarmony系统组件学习
openHarmony系统应用开发的组件很多,本篇文章仅以一个例子作为一个通用的学习方法,如果之前学过安卓开发,这部分内容应该除了语言,其他没有任何难度,本篇文章参考官网实现一个dialog组件,开始了~~
124 0
openHarmony系统组件学习
|
存储 文件存储 芯片
嵌入式开发学习之--创建工程
嵌入式开发学习之--创建工程
嵌入式开发学习之--创建工程
|
Kubernetes Cloud Native Java
关于平台工程的开发者工具链,你还想加点啥?
一个新挑战往往诞生新构思,“内部研发自助平台”构想:“企业应该以平台化建设的方式,提供一系列的自助型工具,协助开发者在各个环节中解决遇到的各种技术问题”。文本会逐步的分析这个工具里面有点啥
387 1
关于平台工程的开发者工具链,你还想加点啥?
|
Linux 芯片
嵌入式linux/鸿蒙开发板(IMX6ULL)开发(三十一)驱动进化之路:设备树的引入及简明教程(下)
嵌入式linux/鸿蒙开发板(IMX6ULL)开发(三十一)驱动进化之路:设备树的引入及简明教程
190 0
嵌入式linux/鸿蒙开发板(IMX6ULL)开发(三十一)驱动进化之路:设备树的引入及简明教程(下)