OpenHarmony设备开发基于IDE开发 轻量系统(基于Hi3861开发板)

zh_ff
发布于 2023-3-16 11:33
浏览
0收藏

编写“Hello World”程序

下方将通过修改源码的方式展示如何编写简单程序,输出“Hello world”。请在下载的源码目录中进行下述操作。

前提条件

已参考​​创建工程并获取源码​​,创建Hi3861开发板的源码工程。

操作步骤

  1. 确定目录结构。
    开发者编写业务代码时,务必先在./applications/sample/wifi-iot/app路径下新建一个目录(或一套目录结构),用于存放业务源码文件。
    例如:在app下新增业务my_first_app,其中hello_world.c为业务代码,BUILD.gn为编译脚本,具体规划目录结构如下:

.
└── applications
    └── sample
        └── wifi-iot
            └── app
                └── my_first_app
                  │── hello_world.c
                  └── BUILD.gn
  1. 编写业务代码。

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

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

3.编写用于将业务构建成静态库的BUILD.gn文件。
新建./applications/sample/wifi-iot/app/my_first_app下的BUILD.gn文件,并完成如下配置。
如步骤1所述,BUILD.gn文件由三部分内容(目标、源文件、头文件路径)构成,需由开发者完成填写。

static_library("myapp") {
    sources = [
        "hello_world.c"
    ]
    include_dirs = [
        "//utils/native/lite/include"
    ]
}

●  static_library中指定业务模块的编译结果,为静态库文件libmyapp.a,开发者根据实际情况完成填写。

●  sources中指定静态库.a所依赖的.c文件及其路径,若路径中包含"//“则表示绝对路径(此处为代码根路径),若不包含”//"则表示相对路径。

●  include_dirs中指定source所需要依赖的.h文件路径。

  1. 添加新组件。

修改文件build/lite/components/applications.json,添加组件hello_world_app的配置,如下所示为applications.json文件片段,"##start##“和”##end##“之间为新增配置(”##start##“和”##end##"仅用来标识位置,添加完配置后删除这两行):

说明: 本章节操作是以OpenHarmony-v3.1-Release版本为例进行操作的,该版本中,组件配置文件为build/lite/components/applications.json;若源码版本大于等于OpenHarmony 3.2 Beta2时,组件配置文件为build/lite/components/communication.json。

{
  "components": [
    {
      "component": "camera_sample_communication",
      "description": "Communication related samples.",
      "optional": "true",
      "dirs": [
        "applications/sample/camera/communication"
      ],
      "targets": [
        "//applications/sample/camera/communication:sample"
      ],
      "rom": "",
      "ram": "",
      "output": [],
      "adapted_kernel": [ "liteos_a" ],
      "features": [],
      "deps": {
        "components": [],
        "third_party": []
      }
    },
##start##
    {
      "component": "hello_world_app",
      "description": "hello world samples.",
      "optional": "true",
      "dirs": [
        "applications/sample/wifi-iot/app/my_first_app"
      ],
      "targets": [
        "//applications/sample/wifi-iot/app/my_first_app:myapp"
      ],
      "rom": "",
      "ram": "",
      "output": [],
      "adapted_kernel": [ "liteos_m" ],
      "features": [],
      "deps": {
        "components": [],
        "third_party": []
      }
    },
##end##
    {
      "component": "camera_sample_app",
      "description": "Camera related samples.",
      "optional": "true",
      "dirs": [
        "applications/sample/camera/launcher",
        "applications/sample/camera/cameraApp",
        "applications/sample/camera/setting",
        "applications/sample/camera/gallery",
        "applications/sample/camera/media"
      ],

5.修改单板配置文件。
修改文件vendor/hisilicon/hispark_pegasus/config.json,新增hello_world_app组件的条目,如下所示代码片段为applications子系统配置,"##start##“和”##end##“之间为新增条目(”##start##“和”##end##"仅用来标识位置,添加完配置后删除这两行):


{
        "subsystem": "applications",
        "components": [
##start##
          { "component": "hello_world_app", "features":[] },
##end##
          { "component": "wifi_iot_sample_app", "features":[] }
        ]
      },


编译

DevEco Device Tool支持Hi3861V100开发板的源码一键编译功能,提供编译工具链和编译环境依赖的检测及一键安装,简化复杂编译环境的同时,提升了编译的效率。

说明: Hi3861V100编译环境为Ubuntu环境。

1. 在菜单栏中点击Project Settings,进入Hi3861工程配置界面。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

2. 在Tool Chain页签中,DevEco Device Tool会自动检测依赖的编译工具链是否完备,如果提示部分工具缺失,可点击Install,自动安装所需工具链。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

  1. 安装Hi3861V100相关工具链,部分工具安装需要使用root权限,请在

说明:如果出现安装pip组件失败,可参考​​修改Python源的方法​​进行修改,完成尝试重新安装。


OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

工具链自动安装完成后如下图所示。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

4. 在wifiiot_hispark_pegasus配置页签中,设置源码的编译类型build_type,默认为"debug"类型,请根据需要进行修改。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

5. 在DevEco Device Tool界面的PROJECT TASKS中,点击对应开发板下的Build,执行编译。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

6. 等待编译完成,在TERMINAL窗口输出“SUCCESS”,编译完成。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

编译完成后,可以在工程的out目录下,查看编译生成的文件,用于后续的​​Hi3861V100开发板烧录​​。


烧录

烧录是指将编译后的程序文件下载到开发板上的动作,为后续的程序调试提供基础。DevEco Device Tool提供一键烧录功能,操作简单,能快捷、高效的完成程序烧录,提升烧录的效率。

Hi3861V100的镜像烧录通过Windows环境进行烧录,开发者启动烧录操作后,DevEco Device Tool通过Remote远程模式,将Ubuntu环境下编译生成的待烧录程序文件拷贝至Windows目录下,然后通过Windows的烧录工具将程序文件烧录至开发板中。

前提条件

操作步骤

  1. 请连接好电脑和待烧录开发板,需要连接USB口,具体可参考​​Hi3861V100开发板介绍​​。
  2. 在DevEco Device Tool中,选择REMOTE DEVELOPMENT > Local PC,查看远程计算机(Ubuntu开发环境)与本地计算机(Windows开发环境)的连接状态。

●  如果Local PC右边连接按钮为

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

,则远程计算机与本地计算机为已连接状态,不需要执行其他操作。

●  如果Local PC右边连接按钮为

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

,则点击绿色按钮进行连接。连接时DevEco Device Tool会重启服务,因此请不要在下载源码或源码编译过程中进行连接,否则会中断任务。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

3. 在菜单栏中点击Project Settings按钮,进入Hi3861V100工程配置界面。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

  1. 在“Tool Chain”页签,设置Uploader烧录器工具,可以通过Tool Chain页签中的Install按钮在线安装。


说明: 若烧录器存在新版本或需要使用其它烧录器,您可以在Uploader > Use Custom Burn Tool

指定本地的烧录器。


OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

5.在“hi3861”页签,设置烧录选项,包括upload_port、upload_protocol和upload_partitions。配置完成后工程将自动保存。

●  upload_port:选择已查询的串口号。

●  upload_protocol:选择烧录协议,选择“hiburn-serial”。

●  upload_partitions:选择待烧录的文件名称。DevEco Device Tool已预置默认的烧录文件信息,如果需要修改待烧录文件地址,可点击每个待烧录文件后的

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

按钮进行修改。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

6. 在“PROJECT TASKS”中,点击hi3861下的Upload按钮,启动烧录。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

7. 启动烧录后,显示如下提示信息时,请在15秒内,按下开发板上的RST按钮重启开发板。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

重新上电后,界面提示如下信息时,表示烧录成功。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区


运行

联网配置

由于Hi3861为WLAN模组,您可以在版本编译及烧录后,通过如下操作,使开发板实现联网功能。

1. 保持Windows工作台和Hi3861 WLAN模组的连接状态,在PROJECT TASKS中,单击Monitor,打开串口终端。
图1 打开DevEco串口终端

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

2. 复位Hi3861 WLAN模组,终端界面显示“ready to OS start”,则启动成功。
图2 Hi3861 WLAN模组复位成功示意图

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

  1. 在DevEco的串口终端中,依次执行如下AT命令,启动STA模式,连接指定AP热点,并开启DHCP功能。

AT+STARTSTA                             # 启动STA模式
AT+SCAN                                 # 扫描周边AP
AT+SCANRESULT                           # 显示扫描结果
AT+CONN="SSID",,2,"PASSWORD"            # 连接指定AP,其中SSID/PASSWORD为待连接的热点名称和密码
AT+STASTAT                              # 查看连接结果
AT+DHCP=wlan0,1                         # 通过DHCP向AP请求wlan0的IP地址
  1. 查看Hi3861 WLAN模组与网关联通是否正常,如下图所示。

AT+IFCFG                                # 查看模组接口IP
AT+PING=X.X.X.X                         # 检查模组与网关的联通性,其中X.X.X.X需替换为实际的网关地址

图3 Hi3861 WLAN模组联网成功示意图

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

调测验证

完成烧录及联网之后,用户可根据需要进行调试验证。目前调试验证的方法有以下两种,开发者可以根据具体业务情况选择。

  1. 通过printf打印日志
  2. 通过asm文件定位panic问题

由于本示例业务简单,采用printf打印日志的调试方式即可。下方将介绍这两种调试手段的使用方法。

printf打印

代码中增加printf维测,信息会直接打印到串口上。开发者可在业务关键路径或业务异常位置增加日志打印,如下所示:

void HelloWorld(void)
{
    printf("[DEMO] Hello world.\n");
}
根据asm文件进行问题定位

系统异常退出时,会在串口上打印异常退出原因调用栈信息,如下文所示。通过解析异常栈信息可以定位异常位置。

=======KERNEL PANIC=======
**Call Stack*
Call Stack 0 -- 4860d8 addr:f784c
Call Stack 1 -- 47b2b2 addr:f788c
Call Stack 2 -- 3e562c addr:f789c
Call Stack 3 -- 4101de addr:f78ac
Call Stack 4 -- 3e5f32 addr:f78cc
Call Stack 5 -- 3f78c0 addr:f78ec
Call Stack 6 -- 3f5e24 addr:f78fc
Call Stack end***

为解析上述调用栈信息,需要使用到Hi3861_wifiiot_app.asm文件,该文件记录了代码中函数在Flash上的符号地址以及反汇编信息。asm文件会随版本打包一同构建输出,存放在./out/wifiiot/路径下。

  1. 将调用栈CallStack信息保存到txt文档中,以便于编辑。(可选)
  2. 打开asm文件,并搜索CallStack中的地址,列出对应的函数名信息。通常只需找出前几个栈信息对应的函数,就可明确异常代码方向。

Call Stack 0 -- 4860d8 addr:f784c -- WadRecvCB
Call Stack 1 -- 47b2b2 addr:f788c -- wal_sdp_process_rx_data
Call Stack 2 -- 3e562c addr:f789c
Call Stack 3 -- 4101de addr:f78ac
Call Stack 4 -- 3e5f32 addr:f78cc
Call Stack 5 -- 3f78c0 addr:f78ec
Call Stack 6 -- 3f5e24 addr:f78fc
    3. 根据以上调用栈信息,可以定位WadRecvCB函数中出现了异常。

OpenHarmony设备开发基于IDE开发  轻量系统(基于Hi3861开发板)-鸿蒙开发者社区

  1. 完成代码排查及修改。

运行结果

示例代码编译、烧录、运行、调测后,重启开发板后将自动在界面输出如下结果:

ready to OS start
FileSystem mount ok.
wifi init success!
[DEMO] Hello world.


文章转载自:​​https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/device-dev/quick-start/quickstart-ide-3861-helloworld.md/​

已于2023-3-17 18:26:36修改
收藏
回复
举报
回复
    相关推荐