驱动模块(6)_Kconfig语法

一、格式

菜单入口 "菜单入口名"
   [依赖]
   [反向依赖]
   [引入其它Kconfig文件]
   ... ...
   [帮助]

配置项 symbol
   值类型
   [输入提示]
   [默认值]
   [依赖]
   [反向依赖]
   ... ...
   [帮助]

 

二、属性

1. 值类型,有 bool/tristate/int/hex/string。只有配置选项有值类型,包括: bool: 值为y或n、 tristate: 值为y或m或n、string: 值为字符串、int: 值为十进制整数、 hex: 值为十六进制整数

 

2. prompt

prompt "提示字符串" [if <expr>]

输入提示,每个菜单入口最多只能有一个展示给用户看的输入提示,可以使用“if”来表示输入提示的依赖性,这个依赖性是可选的。

值类型后可以紧跟一个输入提示(也可以单独使用一个提示属性),所以下面的这两个例子是等价的:

bool "Networking support"
#和
bool
prompt "Networking support"

 

3. default

default <expr> [if <expr>] 

默认值,一个配置选项可以有任意多个默认值,但只有第一个有效的。当输入提示是可见时,才能看到默认值,并且可以输入一个值将默认值覆盖。与输入提示一样,可以使用“if”来表示默认值的依赖性,
这个依赖性是可选的。


4. def_bool/def_tristate

def_bool/def_tristate <expr> ["if" <expr>] 

值类型+默认值,说明值类型时同时说明默认值。可以使用“if”来表示默认值的依赖性,这个依赖性是可选的。


5. depends

depends on <expr-a && expr-b>

依赖,依赖项给菜单入口或配置项定义了一个依赖规则,只有当expr为真或被选中时,该菜单入口或配置项才有效,依赖对菜单入口或配置项中的其它属性都有效。


6. requires

requires <expr> 

依赖,同 depends on。


7. select

select <symbol> ["if" <expr>]

反向依赖,当前配置项被选中时,选中symbol,忽略依赖项和手动设置值。只有boolean和tristate类型的symbol可以使用反向依赖。


8. imply

imply <symbol> [if <expr>]

弱反向依赖:当前配置项被选中时,选中symbol,但是symbol仍然可由依赖或者手动配置为n。


9. range

range <value1> <value2> ["if"<expr>],

值范围,限定int和hex类型symbol的输入值。用户只能输入一个介于value1和value2之间的值,eg: range 12 25 if !H8300。


10. visible

visible if <expr> 

只能用于 menu/endmenu 中,当 expr 为真时菜单可见。


11. help

---help--- / help

帮助,定义了一个帮助文本。帮助文本的结尾是根据缩进级别来决定的,这就意味着如果帮助文本中某一行相对于第一行有更小的缩进,那么这一行就是帮助文档的最后一行。
”—help—”和“help”在使用功能上没有区别,”—help—”是用来作为对开发者的一种提示,它显式区别于文档中的配置选项“help”。


12. option

option <symbol>[=<value>]

其它属性,各种不常见的选项的通过这个选项来定义,比如修改菜单入口的行为和配置symbol。下面这些配置当前是允许的:

defconfig_list: 定义了一系列默认入口,当使用默认配置时可以从这里寻找(当主 .config 文件不存在时会使用默认配置)。
modules: 声明了一个symbol将被当做 MODULES symbol,MODULES symbol是所有配置symbol的第三种模块化状态。
env=<value>: 导入了一个环境变量到Kconfig中。环境变量就像是Kconfig中的一个默认值,但是它是从外部环境中导入的。正因为它从外部环境导入,所以赋值的这个时候它相对于
正常的默认值来说是没有定义的。这个symbol当前没有导出到构建环境中(如果想要这样的话,可以通过另一个symbol导出)。
allnoconfig_y: 声明symol默认值为y。

例如:

config DEFCONFIG_LIST
    option defconfig_list
config EMBEDDED
    option allnoconfig_y
menuconfig MODULES
    option modules

 

三、菜单

1. mainmenu

mainmenu "主菜单名字"

主菜单,也就是最顶层的菜单。


2. menu

menu "string"
    ...
endmenu

多选菜单,带配置项但本身不可配置。它的属性只能是依赖项和可见性。


3. menuconfig

menuconfig 配置关键字
    ...

可选菜单,带配置项且本身就是配置项。配置关键字前面添加 CONFIG_ 后就构成了“.config”文件中的配置项名字。


4. config

config 配置关键字
    ... ...

配置项,配置关键字前面添加 CONFIG_ 后就构成了“.config”文件中的配置项名字,但不是配置界面显示的字符,配置界面显示的是提示字符。


5. choice

choice
...
endchoice

单选菜单,单选菜单只能是bool类型或tristate类型 ,并且布尔选择只允许一个单一的配置项被选中,三态选择还允许任何配置项被设置为“M”。这可以用在下面的情况中使用
如果一个硬件存在多个驱动程序,并且只有一个驱动程序可以编译/加载到内核中,但所有的驱动程序可以编译成模块。

应该就是对提供的多个选项进行单选。


6. comment

comment "..."

注释,这定义了一条在用户配置过程中显示的注释,同时会写入导出文件。它的属性只有依赖项。

 

7. 条件判断

if <expr>
 ... ...
endif

当expr为真或选中时,中间的内容才有效,比如:

config BLK_DEV_INITRD
    ...
if BLK_DEV_INITRD
source "usr/Kconfig"
endif

 

8. source

source "...dir/Kconfig"

引入其他Kconfig文件,方便菜单嵌套。


四、菜单结构

1. 一种是使用了菜单入口明确指定,如下中所有位于“menu”…和“endmenu”之间的入口都是”Network device support”的一个子菜单入口。所有的子入口都继承了菜单入口的依赖项
例如,依赖项”NET”就会被加入到子菜单”NETDEVICESx”的依赖项列表中。

menu "Network device support"
    depends on NET

    config NETDEVICES1
       ...

    config NETDEVICES2
        ... 

endmenu

 

posted on 2022-12-26 17:52  Hello-World3  阅读(730)  评论(0编辑  收藏  举报

导航