驱动模块(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 阅读(684) 评论(0) 编辑 收藏 举报