OpenHarmony下gn相关使用

     OpenHarmony下gn相关使用



引言

为了提高OpenHarmony下移植vivante gpu的成功率,先得把准备工作做足了,这样后续就好搞了。所以本文档的核心工作介绍GN构建工具在OpenHarmony中的常见使用方法,指导三方库由cmake或者其它的脚本构建到GN构建的转换!




一.GN常用的内置变量

名称 描述
current_cpu 当前工具链的处理器架构
current_os 当前工具链的操作系统类型
current_toolchain 表示当前使用的工具链
default_toolchain 表示默认使用的工具链
target_cpu 表示目标平台的CPU类型
target_os 表示目标平台的操作系统类型
root_build_dir 表示根目录的构建目录
root_gen_dir 表示根目录的生成目录
root_out_dir 表示根目录的输出目录
target_out_dir 表示目标文件的输出目录
target_gen_dir 表示中间文件的生成目录
defines 表示当前目标的预定义宏列表
include_dirs 表示当前目标的头文件搜索路径列表
cflags 表示当前目标的C语言编译选项列表
cxxflags 表示当前目标的C++语言编译选项列表
ldflags 表示当前目标的连接选项列表
asmflags 表示当前目标的汇编语言编译选项列表
libs 表示当前目标依赖的库文件列表



二.GN常用的内置函数

名称 描述
assert() 断言函数,如果条件不成立,则会抛出一个异常
defined() 判断变量是否已经定义
exec_script() 执行一个Python脚本
get_label_info() 获取标签信息,例如标签的名称、路径、类型等等
get_path_info() 获取路径信息,例如路径是否存在、是否是目录、是否是文件等等
group() 将一组目标文件组合成一个库文件
import()
### OpenHarmonyGN 文件的作用及用法 #### 一、GN 的基本概念 GN 是 Google 开发的一种元构建系统,用于定义软件项目的结构和依赖关系。它通过描述文件(通常是 `BUILD.gn`),指定目标及其属性来控制构建过程[^1]。 #### 二、GN 文件的主要作用 在 OpenHarmony 系统中,GN 文件主要用于以下几个方面: - **模块化管理**:支持开发者将项目划分为多个独立的模块,并清晰地定义这些模块之间的依赖关系。 - **跨平台兼容性**:提供统一的方式处理不同硬件架构下的编译需求,简化多设备开发流程。 - **高效配置能力**:允许灵活设置编译选项,例如启用或禁用特定功能、调整优化级别等[^2]。 #### 三、GN 文件的基本语法 以下是 GN 文件的一些核心组成部分以及它们的功能解释: ##### 1. 变量声明与赋值 变量可以在 GN 脚本中用来存储字符串或其他数据类型,方便后续引用。 ```gn target_name = "example_module" sources = [ "main.cc", "helper.cc" ] ``` ##### 2. 定义目标 (targets) 每个 BUILD.gn 文件至少包含一个 target 声明,表示要生成的目标产物。 ```gn executable("my_executable") { sources = [ "program.cc" ] } ``` 上述代码片段创建了一个可执行文件目标 my_executable,其中指定了所需的源文件列表。 ##### 3. 配置公共参数 为了减少重复劳动并保持一致性,可以通过 public_configs 或 configs 属性共享某些设定给其他 targets 使用。 ```gn config("default_config") { cflags = [ "-Wall", "-Werror" ] } shared_library("library_with_defaults") { public_configs += [ ":default_config" ] } ``` #### 四、实际案例解析——基于 HDF 驱动开发 假设我们正在为 OpenHarmony 添加一个新的 KHDF 示例驱动,则需要按照如下步骤操作: 1. **新建目录结构** 在合适位置建立子目录存放新组件的相关资源,比如 drivers/sample/khdf_example/[^3]。 2. **编写 BUILD.gn 文件** 下面展示了一段简单的 BUILD.gn 内容作为示范: ```gn import("//build/lite/configs/hdf.gni") hdf_driver("khdf_example") { source_set("src") { sources = [ "driver.c", "interface.h" ] } } ``` 此脚本首先导入了预定义好的宏 hdf.gni 来辅助完成常见任务;接着利用 hdf_driver 函数封装整个驱动逻辑,内部再嵌套 source_set 明确指出参与编译的具体单元。 #### 五、总结 通过对以上内容的学习可以看出,在 OpenHarmony 平台之上运用 GN 工具能够极大地提升工作效率,无论是从组织大型工程还是快速迭代小型实验的角度来看都是不可或缺的技术手段之一。 ```python print("This is an example of Python code block.") ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值