鸿蒙OpenHarmony【编译构建Kconfig可视化配置】子系统

编译构建Kconfig可视化配置指导

概述

功能简介

该功能基于[Kconfiglib]与[Kconfig]实现,方便用户个性化配置OpenHarmony产品子系统部件。

基于Kconfig实现的可视化配置功能具有以下优点:

  • 能直观且全面地展示软件的部件选项。
  • 可靠性强,如Linux-kernel、buildroot等知名软件都采用Kconfig进行可视化配置。

基本概念

  • [Kconfig] :是一款Linux可视化配置文件格式。
  • [Kconfiglib]:是一款基于Kconfig格式实现的Linux可视化配置工具。

相关模块

  • [Kconfig更新模块]:用于更新Kconfig菜单栏目最新的部件信息列表。
  • [config配置格式转换]:用于将界面生成的config文件,转化为系统编译构建的标准化格式配置文件。

操作指导

  1. 获取源码

  2. 环境准备

    环境配置所需要的Kconfiglib已内置在OpenHarmony自带的hb工具中,如需安装hb工具

  3. 开启可视化配置界面

    #进入build仓下目录
    cd build/tools/component_tools
    menuconfig kconfig
    shell
    

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  4. 参数填写

    参数配置项可以参考:productdefine/common/base/base_product.json

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  5. 选择部件并配置

    1. 点击方向键->选择子系统,进入子系统的部件列表。

    2. 按回车健选择子系统。

    3. 输入feature时,注意用英语逗号隔开多项输入。

      外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  6. 保存所选配置

    按S键保存文件,可自定义输出文件名,默认为当前目录下.config文件。

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  7. 生成OpenHarmony Style配置文件

    示例步骤:

    1. gn编译全量产品

      cp productdefine/common/base/base_product.json productdefine/common/products/ohos-arm64.json
      ./build.sh --product-name ohos-arm64  --build-only-gn --ccache --gn-args pycache_enable=true --gn-args check_deps=true --build-only-gn
      shell
      
    2. 生成部件依赖文件

      ./build/tools/module_dependence/part_deps.py --deps-files-path out/arm64/deps_files
      # output: out/arm64/part_deps_info/part_deps_info.json
      shell
      
    3. 生成OpenHarmony Style配置文件

      cd build/tools/component_tools
      python3 parse_kconf.py --deps=/path/to/out/arm64/part_deps_info/part_deps_info.json
      shell
      

      输出文件默认为当前目录下:product.json, 也可以使用python3 parse_kconf.py --out="example/out.json"来指定输出文件位置

      更多操作可查看python3 parse_kconf.py -h

常见问题

菜单列表缺失最新部件信息

由于产品不断的更新迭代,全量部件列表productdefine/common/base/base_product.json也会随之不断更新,从而导致Kconfig菜单缺少最新部件。

解决办法:

更新[Kconfig文件]

cd build/tools/component_tools
python3 generate_kconfig.py
shell

更多选项通过python3 generate_kconfig.py -h查看。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值