鸿蒙轻内核Kconfig使用笔记-进阶

系统
本文在前文的基础上,再介绍下hb set、Makefile和kconfig的关系,然后介绍下如何使用Kconfig图形化配置芯片、设备和产品方案。

[[442379]]

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com

在《鸿蒙轻内核Kconfig使用笔记》一文介绍了Kconfig的基础知识,和鸿蒙轻内核的图形化配置。本文继续介绍些进阶的使用方法。本文中所涉及的源码,均可以在开源站点https://gitee.com/openharmony/kernel_liteos_m 获取,涉及开发板时以fnlink v200zr为例, 芯片开发板相关工程路径如下:

  • https://gitee.com/openharmony/vendor_bestechnic
  • https://gitee.com/openharmony/device_soc_bestechnic
  • https://gitee.com/openharmony/device_board_fnlink

本文在前文的基础上,再介绍下hb set、Makefile和kconfig的关系,然后介绍下如何使用Kconfig图形化配置芯片、设备和产品方案。

1、 hb set、Makefile和kconfig的关系

我们知道在make menuconfig 之前,必须使用hb set设置产品解决方案,下面看下具体是如何做到的。

在kernel\liteos_m\Makefile文件中,有如下makefile片段。⑴处使用makefile foreach命令和shell sed命令循环处理hb set输出的每一行,把“key:value”格式去掉多余的[OHOS INFO]字符,把空格转换为下划线,即转换的格式为“key=value”,然后转换为makefile的变量形式。hb env的输出、shell命令的输出见下文。

  1. ohos_device_path=/home/zhushy/openharmony/device/board/fnlink/v200zr/liteos_m 

⑵处判断解析hb set获取的ohos_kernel内核是否等于liteos_m,如果不等于,则说明未使用hb set设置产品解决解决方案,或者设置的不是liteos_m内核。设置liteos_a\linux内核时,不能在kernel\liteos_m目录下执行make menuconfig。除了ohos_kernel,生成的变量还有ohos_product、ohos_product_path、ohos_device_path、ohos_device_company等等。

⑶处的makefile片段表明,makefile还有make help里面没有提到的参数用法。可以使用make PRODUCT_PATH=XX_Device_Path_XXX等命令来替代使用hb set设置的产品解决方案对应的设备路径。⑷处将这些设置导出为环境变量。在kernel\liteos_m\Kconfig文件中会使用这些环境变量。

  1.   ohos_kernel ?= liteos_m 
  2. ⑴  $(foreach line,$(shell hb env | sed 's/\[OHOS INFO\]/ohos/g;s/ /_/g;s/:_/=/g' || true),$(eval $(line))) 
  3. ⑵  ifneq ($(ohos_kernel),liteos_m) 
  4.     $(error The selected product ($(ohos_product)) is not a liteos_m kernel type product) 
  5.     endif 
  6.  
  7. ⑶  ifeq ($(PRODUCT_PATH),) 
  8.     PRODUCT_PATH:=$(ohos_product_path) 
  9.     endif 
  10.  
  11.     ifeq ($(DEVICE_PATH),) 
  12.     DEVICE_PATH:=$(ohos_device_path) 
  13.     endif 
  14.  
  15.     ifeq ($(BOARD_COMPANY),) 
  16.     BOARD_COMPANY:=$(ohos_device_company) 
  17.     endif 
  18.     ... 
  19. ⑷  export BOARD_COMPANY 
  20.     export DEVICE_PATH 
  21.     export PRODUCT_PATH 

hb env的输出类似如下:

  1. [OHOS INFO] root path: /home/zhushy/openharmony 
  2. [OHOS INFO] board: v200zr 
  3. [OHOS INFO] kernel: liteos_m 
  4. [OHOS INFO] product: iotlink_demo 
  5. [OHOS INFO] product path: /home/zhushy/openharmony/vendor/bestechnic/iotlink_demo 
  6. [OHOS INFO] device path: /home/zhushy/openharmony/device/board/fnlink/v200zr/liteos_m 
  7. [OHOS INFO] device company: fnlink 

 执行shell命令hb env | sed 's/\[OHOS INFO\]/ohos/g;s/ /_/g;s/:_/=/g'的输出如下:

  1. ohos_root_path=/home/zhushy/openharmony 
  2. ohos_board=v200zr 
  3. ohos_kernel=liteos_m 
  4. ohos_product=iotlink_demo 
  5. ohos_product_path=/home/zhushy/openharmony/vendor/bestechnic/iotlink_demo 
  6. ohos_device_path=/home/zhushy/openharmony/device/board/fnlink/v200zr/liteos_m 
  7. ohos_device_company=fnlink 

2、 芯片、单板、扩展板的Kconfig配置

在执行make menuconfig,进入platform配置路径后,可以看到如下图所示的配置界面,支持对扩展板、单板、芯片系列等配置。总体感觉这块后续应该还需要继续优化调整。hb set设置产品解决方案时,已经确定了芯片和开发板,这些也只能在Kconfig界面上展示,是无法配置的。扩展板倒是可以继续选择。后续等支持的开发板和解决方案丰富起来时,hb set设置和kconfig界面设置需要更好的来协作。比如hb set可以支持一系列开发板和解决方案,具体的选择哪些开发板和解决方案,可以kconfig界面上来配置,hb set只提供默认值等等。

鸿蒙轻内核Kconfig使用笔记-进阶-鸿蒙HarmonyOS技术社区

我们来看下对应的makefile片段,深入了解下Kconfig配置的规则。⑴处可以在开发板设备下提供下配置选项,如device\board\fnlink\v200zr\liteos_m目录下维护Kconfig文件提供可定制的配置项。⑵处提供设备的公司名称用来定位构建路径等,这个配置项config SOC_COMPANY只提供string类型、prompt提示、help帮助信息等属性。后续在SOC部分的配置里,如device\soc\bestechnic\Kconfig.liteos_m.soc,继续提供这个配置项的默认值default信息。Kconfig里,运行对同一个config配置项多处出现。

⑶处设置扩展板shields、⑷到⑸用于配置开发板信息,⑹到⑺用于配置芯片族和芯片信息。下文分别详细分析。

  1.     # Device Kconfig import 
  2. ⑴  osource "$(DEVICE_PATH)/Kconfig" 
  3.  
  4. ⑵  config SOC_COMPANY 
  5.         string "SoC company name to locate soc build path" 
  6.         help 
  7.         This option specifies the SoC company name, used to locate the build path for soc. This option is set by the 
  8.         SoC's Kconfig file, and should be exactly the same with SoC company path, and the user should generally avoid 
  9.         modifying it via the menu configuration. 
  10.  
  11. ⑶  orsource "../../device/board/*/Kconfig.liteos_m.shields" 
  12.  
  13. ⑷  orsource "../../device/board/$(BOARD_COMPANY)/Kconfig.liteos_m.defconfig.boards" 
  14.  
  15.     choice 
  16.         prompt "Board Selection" 
  17.  
  18.     orsource "../../device/board/$(BOARD_COMPANY)/Kconfig.liteos_m.boards" 
  19.  
  20. ⑸  endchoice 
  21.  
  22. ⑹  orsource "../../device/soc/*/Kconfig.liteos_m.defconfig" 
  23.  
  24.     choice 
  25.         prompt "SoC Series Selection" 
  26.  
  27.     orsource "../../device/soc/*/Kconfig.liteos_m.series" 
  28.  
  29.     endchoice 
  30.  
  31. ⑺  orsource "../../device/soc/*/Kconfig.liteos_m.soc" 

2.1 扩展板配置

上面的小节中"../../device/board/*/Kconfig.liteos_m.shields"用于配置扩展板信息,使用*通配符匹配所有的扩展板,可以将所有扩展板配置信息都加载进来。设计者认为不同单板厂商的扩展板可以兼容使用吧。还比较有意思的是,Kconfig文件采用liteos_m.shields作为后缀,一方面指明内核类型,又指明是扩展板的配置。fnlink的扩展板设置路径为device\board\fnlink\Kconfig.liteos_m.shields,其内容如下。可以看到又进一步包含shields目录下面Kconfig.liteos_m.shields。

  1. orsource "shields/Kconfig.liteos_m.shields" 

 文件device\board\fnlink\shields\Kconfig.liteos_m.shields的内容如下:⑴处为各个开发板的默认配置项取值,界面上不会显示。⑵处用于展示,并让开发者界面上选择需要的开发板。选择开发板时,对应的一些依赖配置项会被打开,可以自行参考文件device\board\fnlink\shields\v200zr-evb-t1\Kconfig.liteos_m.shield。

  1. ⑴  orsource "*/Kconfig.liteos_m.defconfig.shield" 
  2.  
  3.     choice 
  4.         prompt "shield Selection" 
  5.  
  6. ⑵      orsource "*/Kconfig.liteos_m.shield" 
  7.  
  8.     endchoice 

 下面附上fnlink扩展板目录shields下相关的文件信息:

  1. shields 
  2. ├── BUILD.gn 
  3. ├── Kconfig.liteos_m.shields 
  4. ├── v200zr-evb-t0 
  5. │   ├── BUILD.gn 
  6. │   ├── Kconfig.liteos_m.defconfig.shield 
  7. │   ├── Kconfig.liteos_m.shield 
  8. └── v200zr-evb-t1 
  9.     ├── BUILD.gn 
  10.     ├── Kconfig.liteos_m.defconfig.shield 
  11.     ├── Kconfig.liteos_m.shield 

2.2 开发板配置

文件"../../device/board/$(BOARD_COMPANY)/Kconfig.liteos_m.defconfig.boards"提供指定公司的开发板的默认配置项信息,如文件device\board\fnlink\Kconfig.liteos_m.defconfig.boards内容如下,又进一步引入公司各个开发板的默认配置项信息,可以具体查看文件device\board\fnlink\v200zr\Kconfig.liteos_m.defconfig.board了解下公司开发板默认配置项信息。默认配置项信息不会在配置界面上进行展示。

  1. orsource "*/Kconfig.liteos_m.defconfig.board" 

 文件"../../device/board/$(BOARD_COMPANY)/Kconfig.liteos_m.boards"提供指定公司开发板的配置项信息,如文件device\board\fnlink\Kconfig.liteos_m.boards的配置项如下,又进一步引入公司各个开发板的默认配置项信息,可以具体查看文件device\board\fnlink\v200zr\Kconfig.liteos_m.board了解下公司开发板配置项信息。这些配置项用于在界面上供开发者选择所需的开发板。因为开发板依赖SoC配置项,SoC在hb set时已经确认,这里的配置在界面上只起到展示作用,开发者并不能进行选择配置,这块预计后续会继续优化。

  1. orsource "*/Kconfig.liteos_m.board" 

 device\board\fnlink\v200zr\Kconfig.liteos_m.board内容如下:

  1. config BOARD_V200ZR 
  2.     bool "select board V200Z-R" 
  3.     depends on SOC_BES2600W 

2.3 芯片配置

文件"../../device/soc/*/Kconfig.liteos_m.defconfig"提供芯片系列的默认配置项信息,如文件device\soc\bestechnic\Kconfig.liteos_m.defconfig内容如下,又进一步把各个芯片型号的默认配置信息引入进来,如device\soc\bestechnic\bes2600\Kconfig.liteos_m.defconfig.series。

  1. rsource "*/Kconfig.liteos_m.defconfig.series" 
  2.  
  3. config HALS_COMMUCATION_WIFI_LITE 
  4.     bool "WIFI LITE" 
  5.     default y 

 在"SoC Series Selection"Soc系列选择项中,使用的"../../device/soc/*/Kconfig.liteos_m.series"会把SoC各个系列的配置项引入进来,如device\soc\bestechnic\Kconfig.liteos_m.series,文件内容如下,会进一步把文件device\soc\bestechnic\bes2600\Kconfig.liteos_m.series引入进来。细心的同学可能已经注意到,文件Kconfig.liteos_m.series在目录bestechnic和目录bestechnic\bes2600下都有,属于同名文件。所以,Kconfig中的路径通配符*只通配了一级目录。

  1. rsource "*/Kconfig.liteos_m.series" 

 SoC和SoC Serial的配置项类似,可以自行查看。

小结

本文在前文的基础上,先介绍下hb set、Makefile和kconfig的关系,然后介绍下如何使用Kconfig图形化配置芯片、设备和产品方案。因为时间关系,仓促写作,或能力限制,若有失误之处,请各位读者多多指正。

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com

 

责任编辑:姜华 来源: 鸿蒙社区
相关推荐

2021-12-22 22:32:48

鸿蒙HarmonyOS应用

2024-04-14 18:43:18

2022-03-11 20:23:14

鸿蒙源码分析进程管理

2021-07-06 09:45:03

鸿蒙HarmonyOS应用

2019-08-15 16:00:21

Linux内核Kconfig

2010-05-31 17:06:35

MySQL游标

2020-10-09 09:21:45

鸿蒙

2022-01-12 10:50:23

鸿蒙HarmonyOS应用

2022-01-10 15:31:44

鸿蒙HarmonyOS应用

2022-04-13 11:02:12

鸿蒙事件模块事件Event

2022-03-31 16:26:49

鸿蒙源码分析进程管理

2022-03-03 18:28:28

Harmony进程任务管理模块

2012-05-03 08:34:15

LinuxKconfig

2021-05-08 15:14:50

鸿蒙HarmonyOS应用

2021-05-17 09:28:59

鸿蒙HarmonyOS应用

2021-11-05 15:00:33

鸿蒙HarmonyOS应用

2021-11-08 15:06:15

鸿蒙HarmonyOS应用

2021-06-04 14:15:10

鸿蒙HarmonyOS应用

2010-06-01 18:47:11

Rsync 使用

2021-06-04 09:57:49

鸿蒙HarmonyOS应用
点赞
收藏

51CTO技术栈公众号