Kconfig 详述

Kconfig

简介

Kconfig 严格来讲是一种编程语言,它拥有自己的语法及结构。正是这些语法和结构组成了menuconfig在用户眼前不同的表现形式。

  • Kconfig 文件用于定义各种配置选项,例如是否启用某个设备驱动、特定的文件系统支持、网络协议等。
  • 每个选项都有一个唯一的标识符和一个描述,描述清楚了该选项的作用和影响。
  • Kconfig 允许定义选项之间的依赖关系和冲突关系。例如,某个功能可能依赖于另一个功能或硬件支持,Kconfig 可以确保这些依赖关系在配置时得到正确处理。
  • 使用条件语句和选项依赖,Kconfig 可以根据不同的硬件平台或用户需求,动态地决定编译哪些部分的内核。
  • Kconfig 文件通常分布在 Linux 内核源代码树的不同目录中,每个目录下的 Kconfig 文件负责配置该目录下的特定功能或模块。
  • 每个 Kconfig 文件由一系列配置语句组成,包括 configmenuconfigchoicebooltristate 等命令,用于定义选项、菜单、选择项和选项的数据类型。

Kconfig 菜单结构

配置文件内是一组按树结构组织的配置选项集合。

+- 菜单块
|  +- 菜单条目1 (选项(config)、菜单(menu)、菜单结束(endmenu)、菜单选择(choice))
|  +- 菜单条目2 (选项(config)、菜单(menu)、菜单结束(endmenu)、菜单选择(choice))
|  +- ...

具体案例如下:

menu "Network device support"
      depends on NET

config NETDEVICES
      ...

endmenu

菜单条目

Kconfig 文件由多个菜单条目组成,这些条目可以包含配置选项(config)、菜单(menu)、注释(comment)、菜单选择(choice)等

单个配置选项定义示例如下:

config MODVERSIONS
      bool "Set version information on all module symbols"
      depends on MODULES
      help
        Usually, modules have to be recompiled whenever you switch to a new kernel.

每一行以关键词开始,并可以跟随多个参数。“config”开始一个新的配置条目。接下来的行定义了该配置选项的属性。属性可以包括配置选项的类型、输入提示、依赖关系、帮助文本和默认值。

可以在多个地方定义同一个配置选项,但每个定义只能有一个输入提示,并且所有定义中的选项类型必须一致。
配置选项可以多次定义同一名称
1、你可以在不同的 Kconfig 文件或同一个文件的不同位置,重复定义一个配置选项,只要它们的名称相同。
2、这种重复定义通常是为了在不同的上下文中提供不同的选项描述或依赖关系。
但每个定义只能有一个输入提示
1、虽然你可以多次定义同一个配置选项,但在每个定义中,这个选项只能有一个输入提示。
2、输入提示是配置界面上显示给用户的描述文本,用于说明该选项的功能。
且类型不能冲突
1、每个配置选项的类型(例如 boolintstring 等)在所有定义中必须一致,不能有冲突。
2、这意味着你不能在一个地方定义 config MODVERSIONSbool 类型,然后在另一个地方定义它为 int 类型。

Kconfig 语法

配置文件描述了一系列菜单条目,每行以一个关键字开头(帮助文本除外)。以下关键字会结束一个菜单条目:

  • config
  • menuconfig
  • choice/endchoice
  • comment
  • menu/endmenu
  • if/endif
  • source

前五个关键字也用于递归定义菜单条目。

config

config <symbol>
<config options>

定义一个配置符号 <symbol>,并接受任何条目属性作为选项。

menuconfig

menuconfig <symbol>
<config options>

类似于上述的简单配置条目,但它还向前端提供一个提示,即所有子选项应显示为单独的选项列表。为了确保所有子选项都显示在 menuconfig 条目下而不是外部,需要确保 <config options> 列表中的每个条目都依赖于 menuconfig 符号。这可以通过以下两种构造之一实现:

  1. menuconfig M
    if M
        config C1
        config C2
    endif
    
  2. menuconfig M
    config C1
        depends on M
    config C2
        depends on M
    

在以下示例 (3) 和 (4) 中,虽然 C1 和 C2 仍然依赖于 M,但它们将不再出现在 menuconfig M 之下,因为 C0 不依赖于 M:

  1. menuconfig M
     config C0
    if M
        config C1
        config C2
    endif
    
  2. menuconfig M
    config C0
    config C1
        depends on M
    config C2
        depends on M
    

choices

choice
<choice options>
<choice block>
endchoice

定义一个选择组,并接受上述任何属性作为选项。一个选择组只允许选择一个配置条目。

comment

comment <prompt>
<comment options> # 只能是依赖项

定义一个注释,在配置过程中显示给用户,并回显到输出文件中。唯一可以添加的属性是依赖项。

menu

menu <prompt>
<menu options>
<menu block>
endmenu

定义一个菜单块,参见上文的“菜单结构”部分了解更多信息。唯一可能的选项是依赖项和“可视选项”属性。

菜单依赖

先看下文:

menu "Network device support"
      depends on NET

config NETDEVICES
      ...

endmenu

所有在menu...endmenu块中的条目成为 Network device support 的子菜单。所有子条目继承菜单条目的依赖关系,例如,这意味着 NET 依赖关系被添加到配置选项 NETDEVICES 的依赖列表中(NETDEVICES 也依赖 NET)。

if

if <expr>
<if block> # 菜单条目
endif

定义一个 if 块。依赖表达式 <expr> 将附加到所有包含的菜单条目。

source

source <path>

读取指定的配置文件(Kconfig 文件)。该文件总是被解析。

mainmenu

mainmenu <prompt>

如果配置程序选择使用它,则设置配置程序的标题栏。它应放置在配置的顶部,在任何其他语句之前。

# 单行注释

在源文件行中的任意位置,未引用的 # 字符表示源文件注释的开始。该行的其余部分为注释。

条目属性

配置类型

类型定义:bool / tristate / string / hex / int

基本类型只有两种:tristate(三态)string,其他类型基于这两种类型。

输入提示

输入提示定义语法:prompt <expr> [if <expr> ],每个菜单条目最多可以有一个提示,用于显示给用户。可选地,可以通过“if”添加仅适用于该提示的依赖关系。

也可以在类型定义后选择接受一个输入提示,以下两个对输入提示的定义是等价的:

方式一:
bool "Networking support"

方式二:
bool
prompt "Networking support"
默认取值

默认取值定义语法:default <expr> [if <expr>]

一个配置选项可以有任意数量的默认值。如果多个默认值可见,则只有第一个定义的默认值生效。默认值不限于其定义的菜单条目。这意味着默认值可以在其他地方定义或被更早的定义覆盖。只有当用户没有通过上述输入提示设置其他值时,默认值才会分配给配置符号。如果输入提示可见,默认值会呈现给用户,用户可以覆盖它。可选地,可以通过“if”添加仅适用于该默认值的依赖关系。

依赖关系

依赖关系定义语法:depends on <expr>

如果定义了多个依赖关系, 需要使用&&||来连接。

因为依赖关系也接受if表达式,所以以下两个例子是等价的:

bool "foo" if BAR
default y if BAR
depends on BAR
bool "foo"
default y
反向依赖

反向依赖定义语法:select <symbol> [if <expr>]

反向依赖关系的意思,即当前配置选项被选中,则 <symbol> 就会被选中。

数值范围

数值范围定义语法:range <symbol1> <symbol2> [if <expr>]

这将限制 int 和 hex 符号的可能输入值范围。用户只能输入[symbol1, symbol2]范围内的值(大于等于第一个符号且小于等于第二个符号)。

帮助文本

帮助文本定义语法:help <message>

可视选项

限制菜单显示语法:visible if <expr>

此属性仅适用于菜单块,如果条件为假,则不向用户显示菜单块(其中包含的符号仍然可以被其他符号选择)。

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
linux2.6.x的配置文件kconfig语法linux在2.6版本以后将配置文件由原来的config.in 改为kconfig,对于kconfig的语法在/Documentation/kbuild/kconfig-language.txt中做了详细的说 明,在这里给出kconfig-language.txt的中文版。 介绍 ---- 在配置数据库的配置选项是以树的形式组织的: +- Code maturity level options | +- Prompt for development and/or incomplete code/drivers +- General setup | +- Networking support | +- System V IPC | +- BSD Process Accounting | +- Sysctl support +- Loadable module support | +- Enable loadable module support | +- Set version information on all module symbols | +- Kernel module loader +- ... 每个选项都有其自己的依赖关系。这些依赖关系决定了选项是否是可见的。父选项可见,子选项才能可见。 菜单选项 -------- 大多数的选项都定义了一个配置选项,其它选项则有助于对它们进行组织。(原文:Most entries define a config option, all other entries help to organize them.)一个配置选项定义可以是下面 的形式: config MODVERSIONS bool "Set version information on all module symbols" depends MODULES help Usually, modules have to be recompiled whenever you switch to a new kernel. ... 每行都是以关键字开始,并可以接多个参数。"config" 为定义了一新的配置选项。下面的几行定义了该配置 选项的属性。属性可以是该配置选项的类型,输入提示(input prompt),依赖关系,帮助信息和默认值。一 配置选项可以用相同的名字定义多次,但每个定义只能有一个输入提示并且类型还不能冲突。 菜单属性 -------- 一菜单选项可以有多个属性。并不要求这些属性可以用在任何地方(见语法)。 - 类型定义:"bool"/"tristate"/"string"/"hex"/"int" 每个配置选项都必须指定类型。有两个基本类型:tristate 和 string,其他类型都是基于这两个基本 类型。类型定义可以用输入提示,所以下面的两个例子是等价的: bool "Networking support" 和 bool prompt "Networking support" - 输入提示: "prompt" ["if" ] 每个菜单选项最多只能有一个显示给用户的输入提示。可以用 "if" 来表示该提示的依赖关系,当然这是 可选的。 - 默认值:"default" ["if" ] 一个配置选项可以有任意多个默认值。如果有多个默认值,那么只有第一个被定义的值是可用的。默认值并 不是只限于应用在定义他们的菜单选项。这就意味着默认值可以定义在任何地方或被更早的定义覆盖。 如果用户没有设置(通过上面的输入提示),配置选项的值就是默认值。如果可以显示输入提示的话,就会把 默认值显示给用户,并可以让用户进行修改。 默认值的依赖关系可以用 "if" 添加。(可选项) - 依赖关系:"depends on"/"requires" 为一菜单选项定义依赖关系。如果定义了多个依赖关系,它们之间用 '&&' 间隔。依赖关系也可以应用到 该菜单中所有的其它选项(同样接受一if表达式),所以下面的两个例子是等价的: bool "foo" if BAR default y if BAR and depends on BAR bool "foo" default y - 反向依赖关系:"select" ["if" ] 尽管普通的依赖关系可以降低一选项的上限,反向依赖能将这一限制降的更低。当前菜单选项的值是symbol 的最小值。如果symbol被选择了多次,上限就是其中的最大值。 反向依赖只能用在 boolean 或 tristate 选项上。 - 数据范围:"range" ["if" ] 为int和hex类型的选项设置可以接受输入值范围。用户只能输入大于等于第一个symbol,小于等于第二个 symbol的值。 - 帮助信息: "help" or "---help---" 定义一帮助信息。帮助信息的结束就由缩进的水平决定的,这也就意味着信息是在第一个比帮助信息开始行 的缩进小的行结束。 "---help---" 和 "help" 在实现的作用上没有区别,"---help---" 有助于将文件中的配置逻辑与 给开发人员的提示分开。 菜单依赖关系 ------------ 依赖关系决定了菜单选项是否可见,也可以减少tristate的输入范围。tristate逻辑比boolean逻辑在表 达式中用更多的状态(state)来表示模块的状态。依赖关系表达式的语法如下: ::= (1) '=' (2) '!=' (3) '(' ')' (4) '!' (5) '&&' (6) '||' (7) 表达式是以优先级的降序列出的。 (1) 将symbol赋给表达式。boolean和tristate类型的symbol直接赋给表达式。所有其它类型的symbol 都赋 'n'。 (2) 如果两个symbol相等,返回'y',否则为'n'。 (3) 如果两个symbol相等,返回'n',否则为'y'。 (4) 返回表达式的值。用于改变优先级。 (5) 返回 (2-/expr/) 的结果。 (6) 返回 min(/expr/,/expr/) 的结果。 (7) 返回 max(/expr/,/expr/) 的结果。 一个表达式的值可以是'n','m'或'y'(或者是计算的结果 0,1,2)。当表达式的值为'm'或'y'的时候,菜 单项才是可见的。 symbol有两种类型:不可变的和可变的。不可变的symbol是最普通的,由'config'语句定义,完全由数字 、字母和下划线组成(alphanumeric characters or underscores)。 不可变的symbol只是表达式的一部分。经常用单引号或双引号括起来。在引号中,可以使用任何字符,使用引 号要用转义字符'\'。 菜单结构 -------- 菜单在树中的位置可由两种方法决定。第一种可以是这样: menu "Network device support" depends NET config NETDEVICES ... endmenu 所有的在"menu" ... "endmenu" 之间都是"Network device support"的子菜单。所有的子菜单选项 都继承了父菜单的依赖关系,比如,"NET"的依赖关系就被加到了配置选项NETDEVICES的依赖列表中。 还有就是通过分析依赖关系生成菜单的结构。如果菜单选项在一定程度上依赖于前面的选项,它就能成为该选 项的子菜单。首先,前面的(父)选项必须是依赖列表中的一部分并且它们中必须有满足下面两个条件的选项: - 如果父选项为'n',子选项必须不可见。 - 如果父选项可见,子选项才能可见。 config MODULES bool "Enable loadable module support" config MODVERSIONS bool "Set version information on all module symbols" depends MODULES comment "module support disabled" depends !MODULES MODVERSIONS 直接依赖 MODULES,这就意味着如果MODULES不为'n',该选项才可见。换句话说,当 MODULES可见时,选项才可见(MODULES的(空)依赖关系也是选项依赖关系的一部分)。 Kconfig 语法 ------------ 配置文件描述了菜单选项,每行都是以一关键字开头(除了帮助信息)。下面的关键字结束一菜单选项: - config - menuconfig - choice/endchoice - comment - menu/endmenu - if/endif - source 前5个同样可以用在菜单选项定义的开始。 config: "config" 定义了一配置选项 并且可以接受任何前面介绍的属性。 menuconfig: "menuconfig" 此关键字和前面的关键字很相似,但它在前面的基础上要求所有的子选项作为独立的行显示。(This is similar to the simple config entry above, but it also gives a hint to front ends, that all suboptions should be displayed as a separate list of options.) choices: "choice" "endchoice" 该关键字定义了一组选择项,并且选项可以是前面描述的任何属性。尽管boolean只允许选择一个配置选项, tristate可以抒多个配置选项设为'm',但选项只能是boolean或tristate类型。这可以在一个硬件有多 个驱动的情况下使用,最终只有一个驱动被编译进/加载到内核,,但所有的驱动都可以编译成模块。 选项可以接受的另一个选项是"optional",这样选项就被设置为'n',没有被选中的。 comment: "comment" 这里定义了在配置过程中显示给用户的注释,该注释还将写进输出文件中。唯一可用的可选项是依赖关系。 menu: "menu" "endmenu" 这里定义了一个菜单,详细信息请看前面的"菜单结构"。唯一可用的可选项是依赖关系。 if: "if" "endif" 这里定义了if结构。依赖关系被加到所有在if ... endif 中的菜单选项中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值