编译构建子系统

编译构建子系统提供了一个基于gn和ninja的编译构建框架,主要提供以下功能:

  • 构建不同芯片平台的产品,如:Hi3516DV300平台。

  • 根据产品配置可以按照组件组装打包产品需要的能力。

简介

在了解编译构建子系统的能力前,应了解如下基本概念:

  • 平台

    开发板和内核的组合,不同平台支持的子系统和组件不同。

  • 子系统

    OpenHarmony整体遵从分层设计,从下向上依次为:内核层、系统服务层、框架层和应用层。系统功能按照“系统 > 子系统 > 组件”逐级展开,在多设备部署场景下,支持根据实际需求裁剪某些非必要的子系统或组件。子系统是一个逻辑概念,是由对应组件构成的逻辑系统。

  • 组件

    对子系统的进一步拆分,可复用的软件单元,它包含源码、配置文件、资源文件和编译脚本;能独立构建,以二进制方式集成,具备独立验证能力的二进制单元。

  • gn

    Generate ninja的缩写,用于产生ninja文件。

  • ninja

    ninja是一个专注于速度的小型构建系统。

目录

/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 编译构建子系统架构图

运作机制

OpenHarmony侧的编译构建流程主要包括以下三个步骤:

  1. 命令行解析:解析待编译的产品名称,加载相关配置。

  2. 调用gn: 根据命令行解析的产品名称和编译类型,配置编译工具链和全局的编译选项。

  3. 执行ninja:启动编译并生成对应的产品版本。

轻量和小型系统

轻量和小型系统的编译构建相关介绍请见build_lite仓的Readme文档。

标准系统

标准系统的编译构建相关介绍请见build仓的Readme文档。

相关仓

build_lite

build