Linux内核学习(六):linux kernel的Kconfig分析
前面我们知道了makefile文件,makefile文件会结合配置文件.config来进行操作。这里就再来看看生成内核.config文件的Kconfig吧。
在内核目录下执行“make menuconfig ARCH=arm CRoSS_COMPILE=arm-linux-”时,就会看到个如图16.3所示的菜单,这就是内核的配置界面。
通过配置界面,可以选择芯片类型、选择需要支持的文件系统,去除不需要的选项等,这就称为“配置内核”。
注意,也有其他形式的配置界面,比如“make config”命令启动字符配置界面,对于每个选项都会依次出现一行提示信息,逐个回答;“make xconfig”命令启动X-windows图形配置界面。
所有配置工具都是通过读取 arch/S(ARCH)/Kconfig 文件来生成配置界面,这个文件是所有配置文件的总入口,它会包含其他目录的Kconfig文件。配置界面如上图所示。
内核源码每个子目录中,都有一个Makefile文件和Kconfig 文件。
Makefile 的作用前面已经讲述,Kconfig 用于配置内核,它就是各种配置界面的源文件。内核的配置工具读取各个Kconfig 文件,生成配置界面供开发人员配置内核,最后生成配置文件.config。
内核的配置界面以树状的菜单形式组织,主菜单下有若干个子菜单,子菜单下又有子菜单或配置选项。每个子菜单或选项可以有依赖关系,这些依赖关系用来确定它们是否显示。只有被依赖项的父项已经被选中,子项才会显示。
Kconfig 文件的语法可以参考Documentation/kbuild/kconfig-language.txt 文件,下面讲述几个常用的语法,并在最后介绍菜单形式的配置界面操作方法。
1. Kconfig文件的基本要素:config 条目(entry)
config 条目常被其他条目包含,用来生成菜单、进行多项选择等。
config 条目用来配置一个选项,或者这么说,它用于生成一个变量,这个变量会连同它的值一起被写入配置文件.config 中。比如有一个config条目用来配置CONFIG LEDS_S3C24XX,根据用户的选择,config文件中可能出现下面3种配置结果中的一个。
以一个例子说明config条目格式,下面代码选自fs/Kconfig 文件,它用于配置CONFIG_JFFS2_FS_POSIX_ACL选项。
代码中包含了几乎所有的元素,下面一一说明。
**第1255行中,config是关键字,表示一个配置选项的开始:**紧跟着的JFFS2_FS_POSIX_ACL是配置选项的名称,省略了前缀“CONFIG”。
**第1256行中,bool表示变量类型,即 CONFIG_JFFS2_FS_POSIX_ACL的类型。**有5种类型: bool、tristate、string、hex和 int。
其中的tristate和 string 是基本的类型,其他类型是它们的变种。
bool变量取值有两种: y和n;
tristate变量取值有3种: y、n和m;
string变量取值为字符串;
hex变量取值为十六进制的数据;
int变量取值为十进制的数据。
“bool”之后的字符串是提示信息,在配置界面中上下移动光标选中它时,就可以通过按空格或回车键来设置CONFIG_JFFS2_FS_POSIX_ACL 的值。
提示信息的完整格式如下,如果使用“if ",则当expr为真时才显示提示信息。在实际使用时,prompt关键字可以省略。
第1257行表示依赖关系,格式如下。只有JFFS2_FS_XATTR配置选项被选中时,当前配置选项的提示信息才会出现,才能设置当前配置选项。注意,如果依赖条件不满足,则它取默认值。
第1258行的表示默认值为y,格式如下:
第1259行表示当前配置选项FFS2_FS_POSIX_ACL被选中时,配置选项FS_POSIX_ACL也会被自动选中,格式如下:
第1260行表示下面几行是帮助信息,帮助信息的关键字有如下两种,它们完全一样。当遇到一行的缩进距离比第一行帮助信息的缩进距离小时,表示帮助信息已经结束。比如第1268行的缩进距离比第1267的缩进距离小,帮助信息到第1267行结束。
(1255,256–>1256(估计是印刷错误))
2、menu条目
menu条目用于生成菜单,格式如下:
它的实际使用并不如它的标准格式那样复杂,下面是一个例子。
menu之后的字符串是菜单名,“menu”和“endmenu”之间有很多config条目。
在配置界面上会出现如下字样的菜单,移动光标选中它后按回车键进入,就会看到这些config条目定义的配置选项。
3、 choice条目
choice条目将多个类似的配置选项组合在一起,供用户单选或多选,格式如下:
实际使用中,也是在“choice”和“endchoice”之间定义多个config条目,比如 arch/arm/Kconfig 中有如下代码:
prompt “ARM system type” 给出提示信息“ARM system type",光标选中它后按回车键进入,就可以看到多个config 条目定义的配置选项。
choice条目中定义的变量类型只能有两种: bool和 tristate,不能同时有这两种类型的变量。
对于 bool类型的 choice条日,只能在多个选项中选择一个;
对于tristate类型的choice条目,要么就把多个(可以是一个)选项都设为m;要么就像bool类型的choice条目一样,只能选择一个。这是可以理解的,比如对于同一个硬件,它有多个驱动程序,可以选择将其中之一编译进内核中(配置选项设为y),或者把它们都编译为模块(配置选项设为m)。
4、comment条目
comment条目用于定义一些帮助信息,它在配置过程中出现在界面的第一行;并且这些帮助信息会出现在配置文件中(作为注释),格式如下:
实际使用中也很简单,比如arch/arm/Kconfig 中有如下代码:
进入菜单“Floating point emulation —>”之后,在第一行会看到如下内容:
而在.config文件中也会看到如下内容:
5. source条目
source条目用于读入另一个Kconfig文件,格式如下:
下面是一个例子,取自arch/arm/Kconfig 文件,它读入net/Kconfig 文件。
6.菜单形式的配置界面操作方法
配置界面的开始几行就是它的操作方法,如图16.4所示。
到这里我们已经会看配置文件和操作linux的界面配置,下面来看看linux内核的配置选项吧,
7、Linux内核配置选项
Linux内核配置选项多达上千个,一个个地进行选择既耗费时间,对开发人员的要求也比较高(需要了解每个配置选项的作用)。
一般的做法是在某个默认配置文件的基础上进行修改,比如我们可以先加载配置文件 arch/arm/configs/s3c2410_defconfig,再增加、去除某些配置选项。(根据自己的硬件选择相应的配置文件)
下面分3部分介绍内核配置选项,先从整体介绍主菜单的类别,然后分别介绍和移植系统关系比较密切的“System Type”、“Device Drivers”菜单。
7.1、配置界面主菜单的类别
表16.4讲解了主菜单的类别,以后读者配置内核时,可以根据自己所要设置的功能进入某个菜单,然后根据其中各个配置选项的帮助信息进行配置。
7.2 、“System Type”菜单:系统类型
对于arm平台(在顶层 Makefile中修改“ARCH ?= arm"),执行“make menuconfig”后在配置界面可以看到“System Type”字样,进入它得到另一个界面,如图16.5所示。
7.3、“Device Drivers”菜单:设备驱动程序
执行“make menuconfig”后在配置界面可以看到“Device Drivers”字样,进入它则进入如图16.6所示界面。
到这我们完成了内核的配置,下一步是不是就该让这个内核动起来了,不能光吃饭不干活呀
下一篇见哦宝,等你