# 编译构建子系统
编译构建子系统提供了一个基于gn和ninja的编译构建框架,主要提供以下功能:
- 构建不同芯片平台的产品,如:Hi3516DV300平台。
- 根据产品配置可以按照组件组装打包产品需要的能力。
## 简介
在了解编译构建子系统的能力前,应了解如下基本概念:
- 平台
开发板和内核的组合,不同平台支持的子系统和组件不同。
- 子系统
OpenHarmony整体遵从分层设计,从下向上依次为:内核层、系统服务层、框架层和应用层。系统功能按照“系统 \> 子系统 \> 组件”逐级展开,在多设备部署场景下,支持根据实际需求裁剪某些非必要的子系统或组件。子系统是一个逻辑概念,是由对应组件构成的逻辑系统。
- 组件
对子系统的进一步拆分,可复用的软件单元,它包含源码、配置文件、资源文件和编译脚本;能独立构建,以二进制方式集成,具备独立验证能力的二进制单元。
- gn
Generate ninja的缩写,用于产生ninja文件。
- ninja
ninja是一个专注于速度的小型构建系统。
## 目录
```text
/build # 编译构建主目录
├── __pycache__
├── build_scripts/ # 编译相关的python脚本
├── common/
├── config/ # 编译相关的配置项
├── core
│ ├── gn/ # 编译入口BUILD.gn配置
│ └── build_scripts/
├── docs
├── gn_helpers.py*
├── lite/ # hb和preloader入口
├── misc/
├── ohos # OpenHarmony编译打包流程配置
│ ├── kits # kits编译打包模板和处理流程
│ ├── ndk # ndk模板和处理流程
│ ├── notice # notice模板和处理流程
│ ├── packages # 版本打包模板和处理流程
│ ├── sa_profile # sa模板和处理流程
│ ├── sdk # sdk模板和处理流程,包括sdk中包含的模块配置
│ └── testfwk # 测试相关的处理
├── ohos.gni* # 汇总了常用的gni文件,方便各个模块一次性import
├── ohos_system.prop
├── ohos_var.gni*
├── prebuilts_download.sh* # 预编译脚本
├── print_python_deps.py*
├── scripts/
├── subsystem_config.json
├── subsystem_config_example.json
├── templates/ # c/c++编译模板定义
├── test.gni*
├── toolchain # 编译工具链配置
├── tools # 常用工具
├── version.gni
├── zip.py*
```
**图 1** 编译构建子系统架构图
![](figures/build_framework_ZN.png "编译构建子系统架构图")
## 运作机制
OpenHarmony侧的编译构建流程主要包括以下三个步骤:
1. 命令行解析:解析待编译的产品名称,加载相关配置。
2. 调用gn: 根据命令行解析的产品名称和编译类型,配置编译工具链和全局的编译选项。
3. 执行ninja:启动编译并生成对应的产品版本。
## 轻量和小型系统
轻量和小型系统的编译构建相关介绍请见[build\_lite](https://gitee.com/openharmony/build_lite)仓的Readme文档。
## 标准系统
标准系统的编译构建相关介绍请见[build](https://gitee.com/openharmony/build)仓的Readme文档。
## 相关仓
[build\_lite](https://gitee.com/openharmony/build_lite/blob/master/README_zh.md)
[build](https://gitee.com/openharmony/build/blob/master/README_zh.md)