内容发布更新时间 : 2025/1/23 12:39:48星期一 下面是文章的全部内容请认真阅读。
kbuild与KMakefile
kbuild与KMakefile
Software ? kernel ? kbuild与KMakefile FoldUnfold Table of Contents
顶层Makefile 关于.version
用yes命令回答make oldconfig build and install modules $(call if_changed, xxx) FORCE 顶层Makefile
默认的Makefile的入口点是第一条规则。而Linux内核的Makefile的第一条规则是这样的: 除去上面一长串赋值语句,来到: PHONY := _all _all:
是一条空规则。奇怪的是,下面不远处有如下规则: ifeq ($(KBUILD_EXTMOD),) _all: all else
_all: modules endif
也就是说目标_all被写了两遍。
原因如下:一般Makefile是不允许一个目标被重复写两遍的,如: a: echo a1 a: echo a2
这种情况会生成一条警告,说一条规则将被忽略。但如果第一条规则是一条空规则则是可以的,如: a: a: echo a2
而且还有如下用法: b: echo b a: echo a
此Makefile如果直接make将会执行echo b,因为这是第一条规则,会被当成默认规则。但如果写成下面的样子: a:
b: echo b a: echo a
由于第一条空规则的存在,echo a会被当成默认规则执行。 因此Linux内核中的Makefile的_all可以做如下解释: 真正的入口点是
ifeq ($(KBUILD_EXTMOD),) _all: all else
_all: modules endif
这不必保证这几行代码是第一条规则,之前还可以插入任何内容,只需要保证空规则 _all:
是整个文件的第一条规则,正真入口点处的规则便会被当成默认规则被执行。 关于.version
make distclean后第一次make会在顶层目录生成.version文件.
内核在启动时打印出的如下第一句话
Linux version 2.6.23.17-alp_nl-kzm-arm11-g55714743