Kconfig

Kconfig note:

在hardware/intel/linux-2.6/arch/x86/configs/*****defconfig 里面出现的配置,如:CONFIG_X86_32=y ,

X86_32, 必须在某个Kconfig 里面与预先定义。

也就是说:Kconfig 是定义的地方,可以有个default值

***defconfig文件时重新为具体某个项目 配置这些值的地方。




1:

源头


在根目录下有个Kconfig文件,这就是一切故事的起源。

整个文件就没几行,打出来看一眼。


#
# For a description of the syntax of this configuration file,
# see Documentation/kbuild/kconfig-language.txt.
#
mainmenu "Linux/$ARCH $KERNELVERSION Kernel Configuration"

config SRCARCH
    string
    option env="SRCARCH"

source "arch/$SRCARCH/Kconfig"

第一行就是输出个内核版本号。

第二行应该是配置一个环境变量? 不知道,以后再来看。

第三行很重要,这个是包含了一个arch目录下的Kconfig文件。


当你打开这个文件的时候,你就发现这是一切的开始。

我们运行make menuconfig, 你可以看到,这个文件就是make menuconfig中显示的东西。

一切都变得明朗起来,你是否有种太极生两仪,两仪生四象,四象生八卦的神奇感觉


剪不断,理还乱


kernel中这么多的模块之间的依赖关系,简直就是 剪不断,理还乱。

幸好在Kconfig文件中,我们可以找到一点蛛丝马迹。


依赖 depends on

这个关键字表示了在某些配置选中后,本配置项才会显示。

在 driver/pci/Kconfig文件中有,

config PCI_MSI
    bool "Message Signaled Interrupts (MSI and MSI-X)"
    depends on PCI
    depends on ARCH_SUPPORTS_MSI

可以发现,要配置MSI必须要先支持PCI。 恩这个道理咱都懂, 连PCI都没有,哪里来的MSI啊。


反向依赖 select

这个关键字表示了当本配置项选中后,其他的配置项也需要选中。

在 arch/x86/Kconfig文件中有:

config HIGHMEM64G
    bool "64GB"
    depends on !M386 && !M486
    select X86_PAE
    ---help---
      Select this if you have a 32-bit processor and more than 4
      gigabytes of physical RAM.

其实这个我也不懂,看上去就是说要支持更多的物理内存,那么在x86的平台上,就要选中X86_PAE。

看上去是这么回事儿。


2:

   当我们编写完一个驱动后,我们要把它以模块形式编译或者直接编译进内核时,需要修改相关文件,其中最重要的便是kconfig ,makefile。主要是分析一下三者之间的关系,然后就其语法简要的谈一下。

     当我们在内核源码目录下执行make (或者make menuconfig等命令)命令时,实际上是根据makefile 来进行编译的。我在mini2440开发板上编写了一个按键控制led灯的驱动。文件名为buttons_leds_zhao.c属于字符驱动。因此在/driver/char/目录下的makefile部分最后添加一行

obj-$(CONFIG_BUTTONS_LEDS_ZHAO)      += buttons_leds_zhao.o

如下:

obj-y += mem.o random.o tty_io.o n_tty.o tty_ioctl.o  tty_ldisc.o tty_buffer.o tty_port.o 


obj-$(CONFIG_BFIN_JTAG_COMM) += bfin_jtag_comm.o 


obj-$(CONFIG_CONSOLE_TRANSLATIONS) += consolemap.o consolemap_deftbl.o 


obj-$(CONFIG_HW_CONSOLE) += vt.o defkeymap.o 


obj-$(CONFIG_AUDIT) += tty_audit.o

obj-$(CONFIG_BUTTONS_LEDS_ZHAO)    += buttons_leds_zhao.o

其中第一行obj-y  中的y表示编译进内核,而obj-$(CONFIG_LEGACY_PTYS)  CONFIG_LEGACY_PTYS则表示一个变量,类似于我们C语言中的变量,用$( )来表示,它一般可以取三种值y ,m ,n.y表示编译进内核,而m则表示以模块的方式进行编译,n表示不编译进内核。obj-y    += 等号后面的.o后缀文件则是由该目录下的对应名称的.c文件编译而来。而上面CONFIG_LEGACY_PTYS变量的取值则是通过.config文件来集中赋值的。.config部分内容如下

# Character devices 

CONFIG_VT=y 
CONFIG_CONSOLE_TRANSLATIONS=y 
CONFIG_VT_CONSOLE=y 
CONFIG_HW_CONSOLE=y 
# CONFIG_VT_HW_CONSOLE_BINDING is not set 
# CONFIG_DEVKMEM is not set 
CONFIG_MINI2440_HELLO_MODULE=m 
CONFIG_BUTTONS_LEDS_ZHAO=m 
CONFIG_LEDS_MINI2440=m 
CONFIG_MINI2440_BUTTONS=m 
CONFIG_MINI2440_BUZZER=y 
CONFIG_MINI2440_ADC=y 
# CONFIG_SERIAL_NONSTANDARD is not set

     从上面几行我们可以看到,在makefile里面的变量都是在.config中赋值的。当我们在源代码目录下输入make命令时,都是默认从.config中读入。

     因此,在输入make之前,用ls  -a 查看一下是否有该文件。对于只包含几个文件的工程来说,手动写.configmakefile并不是一件很难的事情,但如果是一个包含有几百个文件的项目来说,则是一件比较困难的事情。可以用autoconf来自动生成.configautomake来制作makefile。看起来问题是解决的,但实际上,这种做法缺乏一定的灵活性,不能实现按需定制的要求。如果要添加或删掉某个驱动,将要在.config文件中找到相应的项进行修改。非常的不方便。因此,便出现了kconfig

当我们在内核源码目录下输入make menuconfig时,出现如下内容:

.config - Linux Kernel v2.6.32.2 Configuration 
──────────────────────────────────────────────────────────────────────────────────────────────── 

┌──────────Linux Kernel Configuration────────────────────┐ 
│  Arrow keys navigate the menu.   selects submenus --->.  Highlighted letters are          │ 
│  hotkeys.  Pressing  includes,  excludes,  modularizes features.  Press         
│  to exit,  for Help,  for Search.  Legend: [*] built-in  [ ] excluded   module              │ 
│  < > module capable                                                                                     │ 
│ ┌──────────────────────────────────────────────┐ │ 
│ │             General setup  --->                                                               ││ 
│ │         [*] Enable loadable module support  --->                                       ││ 
│ │         -*- Enable the block layer  --->                                                    ││ 
│ │             System Type  --->                                                                 ││ 
│ │             Bus support  --->                                                                  ││ 
│ │             Kernel Features  --->                                                             ││ 
│ │             Boot options  --->                                                                 ││ 
│ │             CPU Power Management  --->                                                  ││ 
│ │             Floating point emulation  --->                                                  ││ 
│ │             Userspace binary formats  --->                                                │ │ 
│ │             Power management options  --->                                              │ │ 
│ │         [*] Networking support  --->                                                        │ │ 
│ │             Device Drivers  --->                                                              │ │ 
│ │             File systems  --->                                                                 │ │ 
│ └─────────┴(+)────────────────────────────────┘│ 
├──────────────────────────────────────────────┤ 
│