ZephyrOS中对于Kconfig的介绍

描述

这次小编为大家带来的是ZephyrOS系列文章的第五篇,将为大家介绍Kconfig。

这次小编紧接着上篇给大家带来ZephyrOS中对于Kconfig的介绍。

简单的来说,Kconfig就是Zephyr的配置系统,Zephyr内核可以在构建阶段,根据不同的配置,包含特定的应用和平台。而这个配置过程正是通过Kconfig实现的,其也与Linux内核配置所使用的Kconfig完全一致。设计目标就是让我们无需修改源代码就可以完成Zephyr的配置工作,包括内核,硬件,子系统等。通常配置项(也被称作symbol)是在Kconfig文件中定义的。当然不同的配置项之间也是可以存在依赖关系的,比如定义一个符号A,它依赖于B,那么只有当B被使能之后,A才是有效的。同时,所有的符号可以被合并到一个叫做menu/sub-menu的组里面,便于图形化管理。在正式开篇之前,小编先给大家推荐一个小工具,叫做menuconfig,他是一个可选的图形化工具,可以用来查看和修改Kconfig设置:

当然默认是不会打开的,即默认使用west构建工程是不支持menuconfig的,需要传入-t menuconfig参数:

west build –t menuconfig –b mimxrt1060_evksampleshello_world

最终,所有配置项会被生成到一个叫做autoconf.h的文件中,没有用到的代码就不会再被编译系统所编译,以节省代码空间。

下面,介绍Kconfig中的一个比较重要的概念,visible和invisible符号。

首先说visible符号,也就是那些可以在menuconfig窗口中见到的,这些符号,通常都有一个prompt属性,即一个字符串来进行描述,例如:

config FPU bool “Support floating point operations” depends on HAS_FPU

然后,我们就可以在menuconfig界面中找到他:

[ ] Support floating pointoperations

Invisible符号则与之相对,一般没有prompt属性,即字符串来说明,例如:

config CPU_HAS_FPU

bool

help

This symbol is y if the CPU has a hardwarefloating point unit.

他的特殊性在于,这些符号对于用户是不可见的,即不能通过menuconfig提供的图形化工具来配置,只能通过其他手段来修改其的值。

例如,通过Kconfig.defconfig文件设置下面这个符号的值为32:

config FOO_WIDTH

int

我们就可以在Kconfig.defconfig文件中定义:

config FOO_WIDTH

default 32

endif

这样一来,我们就修改了FOO_WIDTH的默认值为32。

要注意的是,Kconfig.defconfig中所定义的默认值会覆盖掉起始值,且优先级比较高。

我们再举一个choice的例子,比起上面我们定义的config形式的变量,choice类似于一种单选框,当有多个配置存在时,只能一个配置项有效,这样一来,达到一个互斥的效果。要如何操作呢?假定有一个choice叫做FOO,他有两个配置项A和B,初始默认值是B:

choice FOO

bool “Foo choice”

default B

config A

bool “A”

config B

bool “B”

endchoice

下面我们把他的默认值修改为A,完成这个操作,除了在Kconfig.defconfig中修改外,我们还可以在prj.conf中添加:

choice FOO

default A

endchoice

当然,这里要注意,如果我们定义了一个invisible的choice变量FOO的话,就只能通过Kconfig.defconfig来修改了。

那么在Zephyr工程中,都有哪些修改默认配置的地方呢?如果只考虑板级(即Zephyr所支持的开发板)+ 应用这一层,大致分为三类:

板子相关的配置文件,一般名为:boards/《ARCH》/《BOARD》/《BOARD》_defconfig

任意的CMake cache文件,以CONFIG_开头

应用配置:

a) 默认prj.conf

b) 通过-DCONF_FILE=《conf_file》指定,进行重载

c) 通过-DOVERLAY_CONFIG=《conf_file》指定,进行扩展

d) 通过prj_《BOARD》.conf进行重载

e) 通过boards/《BOARD》.conf进行扩展

那么小编就不再扩展Kconfig的其他语法了,大家可以参考这里来了解更多。

至此,Zephyr所使用的两大配置系统就大致讲完了,那么有朋友可能会问了,我们什么时候要用DeviceTree什么时候要用Kconfig呢?小编在这里简单总结一下:

使用设备树来描述硬件和启动配置,例如板载外设和设置启动时系统时钟频率等

使用Kconfig来配置哪些源代码将要被放到最终的镜像中,例如是否添加网络的支持,哪个驱动是需要的。

通俗点讲,DeviceTree负责管理那些硬件资源,Kconfig负责管理软件资源。

举个例子,有个设备同时拥有2.4GHz,multi-protocol radio; 蓝牙和802.15.4,那么设备树就用来描述:

是否有radio硬件存在

兼容性驱动

启动阶段配置,比如TX power in dBm

Kconfig文件决定哪个软件包需要被构建,是选择BLE还是选择802.15.4协议栈。

聊到这里,结合上一篇关于DeviceTree的文章,小编就将DeviceTree和Kconfig的一

些知识点分享给大家了,不过,限于篇幅,都只是一些比较简单的介绍,大家可以自行深入探索。

责任编辑:haq

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分