Linux Kernel Makefile預設目標
阿新 • • 發佈:2019-02-15
inux核心的Makefile也不是一般的麻煩。這裡結合Makefile本身的用法對Linux核心的Makefile做一分析。
(1)入口點
預設的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:
是整個檔案的第一條規則,正真入口點處的規則便會被當成預設規則被執行。
(1)入口點
預設的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:
是整個檔案的第一條規則,正真入口點處的規則便會被當成預設規則被執行。