#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用 原创 精华

sunqihan
发布于 2023-8-1 00:36
浏览
3收藏

此博客由金陵科技学院-开放原子开源社-孙启涵编写

在上一篇帖子中,我们学习了Openharmony轻量系统的编译构建https://ost.51cto.com/posts/25293,其中包括了子系统,组件的核心理念、编译构建系统的配置规则等等。下面我们来学习一下编译构建系统的使用。

案例:新增组件

1:根据功能准备开发套件

笔者使用的是润和智能家居开发套件,连接主板和核心板。
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

2:编写/合入组件源码

编写组件源码:applications\sample\component_demo\demo.c
1.在applications/sample下新建component_demo文件夹
2.在component_demo文件夹下新建文件demo.c
3.编写如下代码:
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

#include <stdio.h>
 #include "ohos_init.h"
 void entry(void)
 {
   printf("I am a component.\r\n");
 }
 SYS_RUN(entry);

其中:
1: #include “ohos_init.h” 是Openharmony的特有头文件,它在utils\native\lite\include\ohos_init.h中,在开发中,它提供了一系列入口,用于初始化服务(services)和功能(features)。
2:SYS_RUN(entry) 的意思是让entry函数以“优先级2”在系统启动过程中的“阶段4.system startup”阶段执行。

3:编写组件编译脚本

编写组件编译脚本:在applications\sample\component_demo下新建BUILD.gn文件,编写如下代码
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

static_library("TestComponent"){

   sources = [ "demo.c" ]

   include_dirs = [
       "//utils/native/lite/include",
   ]
}

1.static_library为静态库,“TestComponent"是库名称,最终被编译为"libTestComponent.a”
2.sources里面存放的是源文件
3.include_dirs里存放的是include目录,包括"ohos_init.h"等头文件。

单独编译目标

在组件源码和编译脚本完成之后,我们可以尝试单独编译目标。

首先我们来看一下hb的用法:

打开虚拟机,进去Openharmony的源码目录,鼠标右键选择在终端中打开,输入如下命令:

hb build -h

显示如下:#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

语法:
 hb build -T 路径:目标

在上面的例子中:
语法为:

 hb build -f -T //applications/sample/component_demo:TestComponent

注意:-T是要大写的。
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
可以看到,编译成功完成。

4:添加组件定义

作为一个组件,必须要注册到一个子系统中,Openharmony才会意识到你的存在。
具体内容可以看上一篇帖子:https://ost.51cto.com/posts/25293
找到build\lite\components\applications.json

添加如下定义:
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

{
      "component":"TestComponent",
      "description":"A test component",
      "optional":"true",
      "dirs":[
        "applications/sample/component_demo"
      ],
      "targets":[
        "//applications/sample/component_demo:TestComponent"
      ],
      "adapted_kernel":["liteos_m"]
    },

添加的内容解释如下:
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

5:将组件配置到产品

找到vendor\hisilicon\hispark_pegasus\config.json,添加如下配置:
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

接着我们再来单独编译组件,这与前面编译目标的效果一样(目标就是一个组件),这样会快捷。

语法:

 hb build 组件名称

在终端中输入如下命令

hb build -f TestComponent

#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
编译结果如上。
这样就不用像之前那样想要编译一个组件,还需要它的路径,会更快捷方便。

6:编译产品

在轻量系统中,单独编译的目标或者是组件是不能够独立运行的,这种编译方式适合发现编译错误,但是要烧录运行的话,我们要进行固件的全量编译(hb build -f)。

接下来我们进行全量编译:
执行以下命令:

hb build -f

编译成功结果如下:
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区

7:烧录固件

下面就到了我们熟悉的地方,烧录固件,笔者这里采用的是Hiburn烧录工具,相关细节可以看我这篇贴子:https://ost.51cto.com/posts/25292
下面给出烧录成功之后的样子:#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
烧录完成后,点击disconnect,然后关闭Hiburn烧录工具。

8:运行

运行我们采用的是MobaXterm串口终端工具。相关细节可以看我这篇帖子:https://ost.51cto.com/posts/25292
下面给出运行结果:
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
可以看到,成功的编译运行了刚刚的component_demo组件.

总结:新增组件的案例就是按照这1-8个步骤来完成。再次附上子系统的构建模型,希望大家能有更深的理解。
#jitoa#【Openharmony轻量设备开发】润和智能家居套件-编译构建系统的使用-鸿蒙开发者社区
以上内容如有不足之处,欢迎大家留言指出。希望我们共同努力加油!

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
分类
已于2023-9-13 17:25:09修改
11
收藏 3
回复
举报
5条回复
按时间正序
/
按时间倒序
红叶亦知秋
红叶亦知秋

作者的表图还是一样的清晰明了!

回复
2023-8-1 10:29:02
有故事的王同学
有故事的王同学

构建流程很详细

回复
2023-8-2 16:36:41
笨笨的婧婧
笨笨的婧婧

三个贴一路追下来,作者讲的确实透

回复
2023-8-3 17:29:20
香菜太难吃了
香菜太难吃了

3861可以说是很经典的开发板了

回复
2023-8-4 17:15:35
liurick
liurick

很详细,受教了

回复
2023-8-7 11:28:44
回复
    相关推荐