kconfig makefile

本文详细介绍了Linux内核配置过程中的关键概念,包括Kconfig文件的结构与语法、Makefile的作用及配置选项的定义方式。此外,还通过实例说明如何添加自定义驱动并将其集成到内核配置中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//
kconfig:
//****************************
常 用选项:config xx
1、类型定义:
每个config菜单项都要有类型定义,bool布尔类型、 "tristate三态:内建、模块、移除"  string字符串、 hex十六进制、 integer整型

例 如config HELLO_MODULE
bool "hello test module"

bool 类型的只能选中或不选中,tristate类型的菜单项多了编译成内核模块的选项,假如选择编译成内核模块,则会在.config中生成一个 CONFIG_HELLO_MODULE=m的配置,假如选择内建,就是直接编译成内核影响,就会在.config中生成一个 CONFIG_HELLO_MODULE=y的配置


2、依赖型定义 depends on或requires
指此菜单的出现和否依赖于另一个定义

config HELLO_MODULE
bool "hello test module"
depends on ARCH_PXA

这个例子表明HELLO_MODULE这个菜单项只对XScale处理器有效。

3、 帮助性定义
只是增加帮助用关键字help或---help---

Second: 内核的Makefile
在Linux2.6.x/Documentation/kbuild目录下有周详的介绍有关kernel makefile的知识。



内核的 Makefile分为5个组成部分: 
Makefile 最顶层的Makefile 
.config 内核的当前配置文档,编译时成为顶层Makefile的一部分
arch/$(ARCH)/Makefile 和体系结构相关的Makefile 
s/ Makefile.* 一些Makefile的通用规则 
kbuild Makefile 各级目录下的大概约500个文档,编译时根据上层Makefile传下来的宏定义和其他编译规则,将源代码编译成模块或编入内核。

顶 层的Makefile文档读取 .config文档的内容,并总体上负责build内核和模块。Arch Makefile则提供补充体系结构相关的信息。 s目录下的Makefile文档包含了任何用来根据kbuild Makefile 构建内核所需的定义和规则。

(其中.config的内容是在make menuconfig的时候,通过Kconfig文档配置的结果)

//********************************************
配 置文件描述了菜单选项,每行都是以一关键字开头(除了帮助信息)。下面的关键字结束一菜单选项:
- config
- menuconfig
- choice/endchoice
- comment
- menu/endmenu
- if/endif
- source
前5个同样可以用 在菜单选项定义的开始。

config:

   "config" <symbol>
   <config options>

定 义了一配置选项 <symbol> 并且可以接受任何前面介绍的属性。

menuconfig:
   "menuconfig" <symbol>
   <config options>

此 关键字和前面的关键字很相似,但它在前面的基础上要求所有的子选项作为独立的行显示。(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"
   <choice options>
   <choice block>
   "endchoice"

该关键字定义了一组选择 项,并且选项可以是前面描述的任何属性。尽管boolean只允许选择一个配置选项,
tristate可以抒多个配置选项设为 'm',但选项只能是boolean或tristate类型。这可以在一个硬件有多
个驱动的情况下使用,最终只有一个驱动被编译进 /加载到内核,,但所有的驱动都可以编译成模块。
选项可以接受的另一个选项是"optional",这样选项就被设置为'n',没 有被选中的。

comment:

   "comment" <prompt>
   <comment options>

这 里定义了在配置过程中显示给用户的注释,该注释还将写进输出文件中。唯一可用的可选项是依赖关系。

menu:

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

这里定义了 一个菜单,详细信息请看前面的"菜单结构"。唯一可用的可选项是依赖关系。

if:

   "if" <expr>
   <if block>
   "endif"

这 里定义了if结构。依赖关系<expr>被加到所有在if ... endif 中的菜单选项中。

//******************* 添加 新的驱动文件 **************************************************/
假 设想把自己写的一个flash的驱动程式加载到工程中,而且能够通过menuconfig配置内核时选择该驱动该怎么办呢?能够分三步:

第 一:将您写的flashtest.c 文档添加到/driver/mtd/maps/ 目录下。

第 二:修改/driver/mtd/maps目录下的kconfig文档:
config MTD_flashtest
tristate “ap71 flash"

这样当make menuconfig时 ,将会出现 ap71 flash选项。

第三:修改该目录下makefile文档。
添加如下内 容:obj-$(CONFIG_MTD_flashtest) = flashtest.o

这样, 当您运行make menucofnig时,您将发现ap71 flash选项,假如您选择了此项。该选择就会保存在.config文档中。当您编译内核时,将会读取.config文档,当发现ap71 flash 选项为yes 时,系统在调用/driver/mtd/maps/下的makefile 时,将会把 flashtest.o 加入到内核中。即可达到您的目的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值