資料介紹
隨著(zhù) Linux 操作系統的廣泛應用,特別是 Linux 在嵌入式領(lǐng)域的發(fā)展,越來(lái)越多的人開(kāi)始投身到 Linux 內核級的開(kāi)發(fā)中。面對日益龐大的 Linux 內核源代碼,開(kāi)發(fā)者在完成自己的內核代碼后,都將面臨著(zhù)同樣的問(wèn)題,即如何將源代碼融入到 Linux 內核中,增加相應的 Linux 配置選項,并最終被編譯進(jìn) Linux 內核。這就需要了解 Linux 的內核配置系統。
眾所周知,Linux 內核是由分布在全球的 Linux 愛(ài)好者共同開(kāi)發(fā)的,Linux 內核每天都面臨著(zhù)許多新的變化。但是,Linux 內核的組織并沒(méi)有出現混亂的現象,反而顯得非常的簡(jiǎn)潔,而且具有很好的擴展性,開(kāi)發(fā)人員可以很方便的向 Linux 內核中增加新的內容。原因之一就是 Linux 采用了模塊化的內核配置系統,從而保證了內核的擴展性。
本文首先分析了 Linux 內核中的配置系統結構,然后,解釋了 Makefile 和配置文件的格式以及配置語(yǔ)句的含義,最后,通過(guò)一個(gè)簡(jiǎn)單的例子--TEST Driver,具體說(shuō)明如何將自行開(kāi)發(fā)的代碼加入到 Linux 內核中。在下面的文章中,不可能解釋所有的功能和命令,只對那些常用的進(jìn)行解釋?zhuān)劣谀切](méi)有討論到的,請讀者參考后面的參考文獻。
1. 配置系統的基本結構
Linux內核的配置系統由三個(gè)部分組成,分別是:
Makefile:分布在 Linux 內核源代碼中的 Makefile,定義 Linux 內核的編譯規則;
配置文件(config.in):給用戶(hù)提供配置選擇的功能;
配置工具:包括配置命令解釋器(對配置腳本中使用的配置命令進(jìn)行解釋?zhuān)┖团渲糜脩?hù)界面(提供基于字符界面、基于 Ncurses 圖形界面以及基于 Xwindows 圖形界面的用戶(hù)配置界面,各自對應于 Make config、Make menuconfig 和 make xconfig)。
這些配置工具都是使用腳本語(yǔ)言,如 Tcl/TK、Perl 編寫(xiě)的(也包含一些用 C 編寫(xiě)的代碼)。本文并不是對配置系統本身進(jìn)行分析,而是介紹如何使用配置系統。所以,除非是配置系統的維護者,一般的內核開(kāi)發(fā)者無(wú)須了解它們的原理,只需要知道如何編寫(xiě) Makefile 和配置文件就可以。所以,在本文中,我們只對 Makefile 和配置文件進(jìn)行討論。另外,凡是涉及到與具體 CPU 體系結構相關(guān)的內容,我們都以 ARM 為例,這樣不僅可以將討論的問(wèn)題明確化,而且對內容本身不產(chǎn)生影響。
2. Makefile
2.1 Makefile 概述
Makefile 的作用是根據配置的情況,構造出需要編譯的源文件列表,然后分別編譯,并把目標代碼鏈接到一起,最終形成 Linux 內核二進(jìn)制文件。
由于 Linux 內核源代碼是按照樹(shù)形結構組織的,所以 Makefile 也被分布在目錄樹(shù)中。Linux 內核中的 Makefile 以及與 Makefile 直接相關(guān)的文件有:
Makefile:頂層 Makefile,是整個(gè)內核配置、編譯的總體控制文件。
.config:內核配置文件,包含由用戶(hù)選擇的配置選項,用來(lái)存放內核配置后的結果(如 make config)。
arch/*/Makefile:位于各種 CPU 體系目錄下的 Makefile,如 arch/arm/Makefile,是針對特定平臺的 Makefile。
各個(gè)子目錄下的 Makefile:比如 drivers/Makefile,負責所在子目錄下源代碼的管理。
Rules.make:規則文件,被所有的 Makefile 使用。
用戶(hù)通過(guò) make config 配置后,產(chǎn)生了 .config。頂層 Makefile 讀入 .config 中的配置選擇。頂層 Makefile 有兩個(gè)主要的任務(wù):產(chǎn)生 vmlinux 文件和內核模塊(module)。為了達到此目的,頂層 Makefile 遞歸的進(jìn)入到內核的各個(gè)子目錄中,分別調用位于這些子目錄中的 Makefile。至于到底進(jìn)入哪些子目錄,取決于內核的配置。在頂層 Makefile 中,有一句:include arch/$(ARCH)/Makefile,包含了特定 CPU 體系結構下的 Makefile,這個(gè) Makefile 中包含了平臺相關(guān)的信息。
位于各個(gè)子目錄下的 Makefile 同樣也根據 .config 給出的配置信息,構造出當前配置下需要的源文件列表,并在文件的最后有 include $(TOPDIR)/Rules.make。
Rules.make 文件起著(zhù)非常重要的作用,它定義了所有 Makefile 共用的編譯規則。比如,如果需要將本目錄下所有的 c 程序編譯成匯編代碼,需要在 Makefile 中有以下的編譯規則:
%.s: %.c
$(CC) $(CFLAGS) -S $《 -o $@
有很多子目錄下都有同樣的要求,就需要在各自的 Makefile 中包含此編譯規則,這會(huì )比較麻煩。而 Linux 內核中則把此類(lèi)的編譯規則統一放置到 Rules.make 中,并在各自的 Makefile 中包含進(jìn)了 Rules.make(include Rules.make),這樣就避免了在多個(gè) Makefile 中重復同樣的規則。對于上面的例子,在 Rules.make 中對應的規則為:
%.s: %.c
$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$(*F)) $(CFLAGS_$@) -S $《 -o $@
2.2 Makefile 中的變量
頂層 Makefile 定義并向環(huán)境中輸出了許多變量,為各個(gè)子目錄下的 Makefile 傳遞一些信息。有些變量,比如 SUBDIRS,不僅在頂層 Makefile 中定義并且賦初值,而且在 arch/*/Makefile 還作了擴充。
常用的變量有以下幾類(lèi):
1) 版本信息
版本信息有:VERSION,PATCHLEVEL, SUBLEVEL, EXTRAVERSION,KERNELRELEASE。版本信息定義了當前內核的版本,比如 VERSION=2,PATCHLEVEL=4,SUBLEVEL=18,EXATAVERSION=-rmk7,它們共同構成內核的發(fā)行版本KERNELRELEASE:2.4.18-rmk7
2) CPU 體系結構:ARCH
在頂層 Makefile 的開(kāi)頭,用 ARCH 定義目標 CPU 的體系結構,比如 ARCH:=arm 等。許多子目錄的 Makefile 中,要根據 ARCH 的定義選擇編譯源文件的列表。
3) 路徑信息:TOPDIR, SUBDIRS
TOPDIR 定義了 Linux 內核源代碼所在的根目錄。例如,各個(gè)子目錄下的 Makefile 通過(guò) $(TOPDIR)/Rules.make 就可以找到 Rules.make 的位置。
SUBDIRS 定義了一個(gè)目錄列表,在編譯內核或模塊時(shí),頂層 Makefile 就是根據 SUBDIRS 來(lái)決定進(jìn)入哪些子目錄。SUBDIRS 的值取決于內核的配置,在頂層 Makefile 中 SUBDIRS 賦值為 kernel drivers mm fs net ipc lib;根據內核的配置情況,在 arch/*/Makefile 中擴充了 SUBDIRS 的值,參見(jiàn)4)中的例子。
4) 內核組成信息:HEAD, CORE_FILES, NETWORKS, DRIVERS, LIBS
Linux 內核文件 vmlinux 是由以下規則產(chǎn)生的:
vmlinux: $(CONFIGURATION) init/main.o init/version.o linuxsubdirs
$(LD) $(LINKFLAGS) $(HEAD) init/main.o init/version.o
--start-group
$(CORE_FILES)
$(DRIVERS)
$(NETWORKS)
$(LIBS)
--end-group
-o vmlinux
可以看出,vmlinux 是由 HEAD、main.o、version.o、CORE_FILES、DRIVERS、NETWORKS 和 LIBS 組成的。這些變量(如 HEAD)都是用來(lái)定義連接生成 vmlinux 的目標文件和庫文件列表。其中,HEAD在arch/*/Makefile 中定義,用來(lái)確定被最先鏈接進(jìn) vmlinux 的文件列表。比如,對于 ARM 系列的 CPU,HEAD 定義為:
HEAD ?。? arch/arm/kernel/head-$(PROCESSOR).o
arch/arm/kernel/init_task.o
表明 head-$(PROCESSOR).o 和 init_task.o 需要最先被鏈接到 vmlinux 中。PROCESSOR 為 armv 或 armo,取決于目標 CPU。 CORE_FILES,NETWORK,DRIVERS 和 LIBS 在頂層 Makefile 中定義,并且由 arch/*/Makefile 根據需要進(jìn)行擴充。 CORE_FILES 對應著(zhù)內核的核心文件,有 kernel/kernel.o,mm/mm.o,fs/fs.o,ipc/ipc.o,可以看出,這些是組成內核最為重要的文件。同時(shí),arch/arm/Makefile 對 CORE_FILES 進(jìn)行了擴充:
# arch/arm/Makefile
# If we have a machine-specific directory, then include it in the build.
MACHDIR := arch/arm/mach-$(MACHINE)
ifeq ($(MACHDIR),$(wildcard $(MACHDIR)))
SUBDIRS += $(MACHDIR)
CORE_FILES ?。? $(MACHDIR)/$(MACHINE).o $(CORE_FILES)
endif
HEAD ?。? arch/arm/kernel/head-$(PROCESSOR).o
arch/arm/kernel/init_task.o
SUBDIRS += arch/arm/kernel arch/arm/mm arch/arm/lib arch/arm/nwfpe
CORE_FILES ?。? arch/arm/kernel/kernel.o arch/arm/mm/mm.o $(CORE_FILES)
LIBS ?。? arch/arm/lib/lib.a $(LIBS)
5) 編譯信息:CPP, CC, AS, LD, AR,CFLAGS,LINKFLAGS
在 Rules.make 中定義的是編譯的通用規則,具體到特定的場(chǎng)合,需要明確給出編譯環(huán)境,編譯環(huán)境就是在以上的變量中定義的。針對交叉編譯的要求,定義了 CROSS_COMPILE。比如:
CROSS_COMPILE = arm-linux-
CC = $(CROSS_COMPILE)gcc
LD = $(CROSS_COMPILE)ld
。..。..
CROSS_COMPILE 定義了交叉編譯器前綴 arm-linux-,表明所有的交叉編譯工具都是以 arm-linux- 開(kāi)頭的,所以在各個(gè)交叉編譯器工具之前,都加入了 $(CROSS_COMPILE),以組成一個(gè)完整的交叉編譯工具文件名,比如 arm-linux-gcc。
CFLAGS 定義了傳遞給 C 編譯器的參數。
LINKFLAGS 是鏈接生成 vmlinux 時(shí),由鏈接器使用的參數。LINKFLAGS 在 arm/*/Makefile 中定義,比如:
# arch/arm/Makefile
LINKFLAGS :=-p -X -T arch/arm/vmlinux.lds
6) 配置變量CONFIG_*
.config 文件中有許多的配置變量等式,用來(lái)說(shuō)明用戶(hù)配置的結果。例如 CONFIG_MODULES=y 表明用戶(hù)選擇了 Linux 內核的模塊功能。
.config 被頂層 Makefile 包含后,就形成許多的配置變量,每個(gè)配置變量具有確定的值:y 表示本編譯選項對應的內核代碼被靜態(tài)編譯進(jìn) Linux 內核;m 表示本編譯選項對應的內核代碼被編譯成模塊;n 表示不選擇此編譯選項;如果根本就沒(méi)有選擇,那么配置變量的值為空。
2.3 Rules.make 變量
前面講過(guò),Rules.make 是編譯規則文件,所有的 Makefile 中都會(huì )包括 Rules.make。Rules.make 文件定義了許多變量,最為重要是那些編譯、鏈接列表變量。
O_OBJS,L_OBJS,OX_OBJS,LX_OBJS:本目錄下需要編譯進(jìn) Linux 內核 vmlinux 的目標文件列表,其中 OX_OBJS 和 LX_OBJS 中的 “X” 表明目標文件使用了 EXPORT_SYMBOL 輸出符號。
M_OBJS,MX_OBJS:本目錄下需要被編譯成可裝載模塊的目標文件列表。同樣,MX_OBJS 中的 “X” 表明目標文件使用了 EXPORT_SYMBOL 輸出符號。
O_TARGET,L_TARGET:每個(gè)子目錄下都有一個(gè) O_TARGET 或 L_TARGET,Rules.make 首先從源代碼編譯生成 O_OBJS 和 OX_OBJS 中所有的目標文件,然后使用 $(LD) -r 把它們鏈接成一個(gè) O_TARGET 或 L_TARGET。O_TARGET 以 .o 結尾,而 L_TARGET 以 .a 結尾。
2.4 子目錄 Makefile
子目錄 Makefile 用來(lái)控制本級目錄以下源代碼的編譯規則。我們通過(guò)一個(gè)例子來(lái)講解子目錄 Makefile 的組成:
#
# Makefile for the linux kernel.
#
# All of the (potential) objects that export symbols.
# This list comes from ‘grep -l EXPORT_SYMBOL *.[hc]’。
export-objs ?。? tc.o
# Object file lists.
obj-y ?。?
obj-m ?。?
obj-n ?。?
obj- ?。?
obj-$(CONFIG_TC) += tc.o
obj-$(CONFIG_ZS) += zs.o
obj-$(CONFIG_VT) += lk201.o lk201-map.o lk201-remap.o
# Files that are both resident and modular: remove from modular.
obj-m ?。? $(filter-out $(obj-y), $(obj-m))
# Translate to Rules.make lists.
L_TARGET ?。? tc.a
L_OBJS ?。? $(sort $(filter-out $(export-objs), $(obj-y)))
LX_OBJS ?。? $(sort $(filter $(export-objs), $(obj-y)))
M_OBJS ?。? $(sort $(filter-out $(export-objs), $(obj-m)))
MX_OBJS ?。? $(sort $(filter $(export-objs), $(obj-m)))
include $(TOPDIR)/Rules.make
a) 注釋
對 Makefile 的說(shuō)明和解釋?zhuān)?開(kāi)始。
眾所周知,Linux 內核是由分布在全球的 Linux 愛(ài)好者共同開(kāi)發(fā)的,Linux 內核每天都面臨著(zhù)許多新的變化。但是,Linux 內核的組織并沒(méi)有出現混亂的現象,反而顯得非常的簡(jiǎn)潔,而且具有很好的擴展性,開(kāi)發(fā)人員可以很方便的向 Linux 內核中增加新的內容。原因之一就是 Linux 采用了模塊化的內核配置系統,從而保證了內核的擴展性。
本文首先分析了 Linux 內核中的配置系統結構,然后,解釋了 Makefile 和配置文件的格式以及配置語(yǔ)句的含義,最后,通過(guò)一個(gè)簡(jiǎn)單的例子--TEST Driver,具體說(shuō)明如何將自行開(kāi)發(fā)的代碼加入到 Linux 內核中。在下面的文章中,不可能解釋所有的功能和命令,只對那些常用的進(jìn)行解釋?zhuān)劣谀切](méi)有討論到的,請讀者參考后面的參考文獻。
1. 配置系統的基本結構
Linux內核的配置系統由三個(gè)部分組成,分別是:
Makefile:分布在 Linux 內核源代碼中的 Makefile,定義 Linux 內核的編譯規則;
配置文件(config.in):給用戶(hù)提供配置選擇的功能;
配置工具:包括配置命令解釋器(對配置腳本中使用的配置命令進(jìn)行解釋?zhuān)┖团渲糜脩?hù)界面(提供基于字符界面、基于 Ncurses 圖形界面以及基于 Xwindows 圖形界面的用戶(hù)配置界面,各自對應于 Make config、Make menuconfig 和 make xconfig)。
這些配置工具都是使用腳本語(yǔ)言,如 Tcl/TK、Perl 編寫(xiě)的(也包含一些用 C 編寫(xiě)的代碼)。本文并不是對配置系統本身進(jìn)行分析,而是介紹如何使用配置系統。所以,除非是配置系統的維護者,一般的內核開(kāi)發(fā)者無(wú)須了解它們的原理,只需要知道如何編寫(xiě) Makefile 和配置文件就可以。所以,在本文中,我們只對 Makefile 和配置文件進(jìn)行討論。另外,凡是涉及到與具體 CPU 體系結構相關(guān)的內容,我們都以 ARM 為例,這樣不僅可以將討論的問(wèn)題明確化,而且對內容本身不產(chǎn)生影響。
2. Makefile
2.1 Makefile 概述
Makefile 的作用是根據配置的情況,構造出需要編譯的源文件列表,然后分別編譯,并把目標代碼鏈接到一起,最終形成 Linux 內核二進(jìn)制文件。
由于 Linux 內核源代碼是按照樹(shù)形結構組織的,所以 Makefile 也被分布在目錄樹(shù)中。Linux 內核中的 Makefile 以及與 Makefile 直接相關(guān)的文件有:
Makefile:頂層 Makefile,是整個(gè)內核配置、編譯的總體控制文件。
.config:內核配置文件,包含由用戶(hù)選擇的配置選項,用來(lái)存放內核配置后的結果(如 make config)。
arch/*/Makefile:位于各種 CPU 體系目錄下的 Makefile,如 arch/arm/Makefile,是針對特定平臺的 Makefile。
各個(gè)子目錄下的 Makefile:比如 drivers/Makefile,負責所在子目錄下源代碼的管理。
Rules.make:規則文件,被所有的 Makefile 使用。
用戶(hù)通過(guò) make config 配置后,產(chǎn)生了 .config。頂層 Makefile 讀入 .config 中的配置選擇。頂層 Makefile 有兩個(gè)主要的任務(wù):產(chǎn)生 vmlinux 文件和內核模塊(module)。為了達到此目的,頂層 Makefile 遞歸的進(jìn)入到內核的各個(gè)子目錄中,分別調用位于這些子目錄中的 Makefile。至于到底進(jìn)入哪些子目錄,取決于內核的配置。在頂層 Makefile 中,有一句:include arch/$(ARCH)/Makefile,包含了特定 CPU 體系結構下的 Makefile,這個(gè) Makefile 中包含了平臺相關(guān)的信息。
位于各個(gè)子目錄下的 Makefile 同樣也根據 .config 給出的配置信息,構造出當前配置下需要的源文件列表,并在文件的最后有 include $(TOPDIR)/Rules.make。
Rules.make 文件起著(zhù)非常重要的作用,它定義了所有 Makefile 共用的編譯規則。比如,如果需要將本目錄下所有的 c 程序編譯成匯編代碼,需要在 Makefile 中有以下的編譯規則:
%.s: %.c
$(CC) $(CFLAGS) -S $《 -o $@
有很多子目錄下都有同樣的要求,就需要在各自的 Makefile 中包含此編譯規則,這會(huì )比較麻煩。而 Linux 內核中則把此類(lèi)的編譯規則統一放置到 Rules.make 中,并在各自的 Makefile 中包含進(jìn)了 Rules.make(include Rules.make),這樣就避免了在多個(gè) Makefile 中重復同樣的規則。對于上面的例子,在 Rules.make 中對應的規則為:
%.s: %.c
$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$(*F)) $(CFLAGS_$@) -S $《 -o $@
2.2 Makefile 中的變量
頂層 Makefile 定義并向環(huán)境中輸出了許多變量,為各個(gè)子目錄下的 Makefile 傳遞一些信息。有些變量,比如 SUBDIRS,不僅在頂層 Makefile 中定義并且賦初值,而且在 arch/*/Makefile 還作了擴充。
常用的變量有以下幾類(lèi):
1) 版本信息
版本信息有:VERSION,PATCHLEVEL, SUBLEVEL, EXTRAVERSION,KERNELRELEASE。版本信息定義了當前內核的版本,比如 VERSION=2,PATCHLEVEL=4,SUBLEVEL=18,EXATAVERSION=-rmk7,它們共同構成內核的發(fā)行版本KERNELRELEASE:2.4.18-rmk7
2) CPU 體系結構:ARCH
在頂層 Makefile 的開(kāi)頭,用 ARCH 定義目標 CPU 的體系結構,比如 ARCH:=arm 等。許多子目錄的 Makefile 中,要根據 ARCH 的定義選擇編譯源文件的列表。
3) 路徑信息:TOPDIR, SUBDIRS
TOPDIR 定義了 Linux 內核源代碼所在的根目錄。例如,各個(gè)子目錄下的 Makefile 通過(guò) $(TOPDIR)/Rules.make 就可以找到 Rules.make 的位置。
SUBDIRS 定義了一個(gè)目錄列表,在編譯內核或模塊時(shí),頂層 Makefile 就是根據 SUBDIRS 來(lái)決定進(jìn)入哪些子目錄。SUBDIRS 的值取決于內核的配置,在頂層 Makefile 中 SUBDIRS 賦值為 kernel drivers mm fs net ipc lib;根據內核的配置情況,在 arch/*/Makefile 中擴充了 SUBDIRS 的值,參見(jiàn)4)中的例子。
4) 內核組成信息:HEAD, CORE_FILES, NETWORKS, DRIVERS, LIBS
Linux 內核文件 vmlinux 是由以下規則產(chǎn)生的:
vmlinux: $(CONFIGURATION) init/main.o init/version.o linuxsubdirs
$(LD) $(LINKFLAGS) $(HEAD) init/main.o init/version.o
--start-group
$(CORE_FILES)
$(DRIVERS)
$(NETWORKS)
$(LIBS)
--end-group
-o vmlinux
可以看出,vmlinux 是由 HEAD、main.o、version.o、CORE_FILES、DRIVERS、NETWORKS 和 LIBS 組成的。這些變量(如 HEAD)都是用來(lái)定義連接生成 vmlinux 的目標文件和庫文件列表。其中,HEAD在arch/*/Makefile 中定義,用來(lái)確定被最先鏈接進(jìn) vmlinux 的文件列表。比如,對于 ARM 系列的 CPU,HEAD 定義為:
HEAD ?。? arch/arm/kernel/head-$(PROCESSOR).o
arch/arm/kernel/init_task.o
表明 head-$(PROCESSOR).o 和 init_task.o 需要最先被鏈接到 vmlinux 中。PROCESSOR 為 armv 或 armo,取決于目標 CPU。 CORE_FILES,NETWORK,DRIVERS 和 LIBS 在頂層 Makefile 中定義,并且由 arch/*/Makefile 根據需要進(jìn)行擴充。 CORE_FILES 對應著(zhù)內核的核心文件,有 kernel/kernel.o,mm/mm.o,fs/fs.o,ipc/ipc.o,可以看出,這些是組成內核最為重要的文件。同時(shí),arch/arm/Makefile 對 CORE_FILES 進(jìn)行了擴充:
# arch/arm/Makefile
# If we have a machine-specific directory, then include it in the build.
MACHDIR := arch/arm/mach-$(MACHINE)
ifeq ($(MACHDIR),$(wildcard $(MACHDIR)))
SUBDIRS += $(MACHDIR)
CORE_FILES ?。? $(MACHDIR)/$(MACHINE).o $(CORE_FILES)
endif
HEAD ?。? arch/arm/kernel/head-$(PROCESSOR).o
arch/arm/kernel/init_task.o
SUBDIRS += arch/arm/kernel arch/arm/mm arch/arm/lib arch/arm/nwfpe
CORE_FILES ?。? arch/arm/kernel/kernel.o arch/arm/mm/mm.o $(CORE_FILES)
LIBS ?。? arch/arm/lib/lib.a $(LIBS)
5) 編譯信息:CPP, CC, AS, LD, AR,CFLAGS,LINKFLAGS
在 Rules.make 中定義的是編譯的通用規則,具體到特定的場(chǎng)合,需要明確給出編譯環(huán)境,編譯環(huán)境就是在以上的變量中定義的。針對交叉編譯的要求,定義了 CROSS_COMPILE。比如:
CROSS_COMPILE = arm-linux-
CC = $(CROSS_COMPILE)gcc
LD = $(CROSS_COMPILE)ld
。..。..
CROSS_COMPILE 定義了交叉編譯器前綴 arm-linux-,表明所有的交叉編譯工具都是以 arm-linux- 開(kāi)頭的,所以在各個(gè)交叉編譯器工具之前,都加入了 $(CROSS_COMPILE),以組成一個(gè)完整的交叉編譯工具文件名,比如 arm-linux-gcc。
CFLAGS 定義了傳遞給 C 編譯器的參數。
LINKFLAGS 是鏈接生成 vmlinux 時(shí),由鏈接器使用的參數。LINKFLAGS 在 arm/*/Makefile 中定義,比如:
# arch/arm/Makefile
LINKFLAGS :=-p -X -T arch/arm/vmlinux.lds
6) 配置變量CONFIG_*
.config 文件中有許多的配置變量等式,用來(lái)說(shuō)明用戶(hù)配置的結果。例如 CONFIG_MODULES=y 表明用戶(hù)選擇了 Linux 內核的模塊功能。
.config 被頂層 Makefile 包含后,就形成許多的配置變量,每個(gè)配置變量具有確定的值:y 表示本編譯選項對應的內核代碼被靜態(tài)編譯進(jìn) Linux 內核;m 表示本編譯選項對應的內核代碼被編譯成模塊;n 表示不選擇此編譯選項;如果根本就沒(méi)有選擇,那么配置變量的值為空。
2.3 Rules.make 變量
前面講過(guò),Rules.make 是編譯規則文件,所有的 Makefile 中都會(huì )包括 Rules.make。Rules.make 文件定義了許多變量,最為重要是那些編譯、鏈接列表變量。
O_OBJS,L_OBJS,OX_OBJS,LX_OBJS:本目錄下需要編譯進(jìn) Linux 內核 vmlinux 的目標文件列表,其中 OX_OBJS 和 LX_OBJS 中的 “X” 表明目標文件使用了 EXPORT_SYMBOL 輸出符號。
M_OBJS,MX_OBJS:本目錄下需要被編譯成可裝載模塊的目標文件列表。同樣,MX_OBJS 中的 “X” 表明目標文件使用了 EXPORT_SYMBOL 輸出符號。
O_TARGET,L_TARGET:每個(gè)子目錄下都有一個(gè) O_TARGET 或 L_TARGET,Rules.make 首先從源代碼編譯生成 O_OBJS 和 OX_OBJS 中所有的目標文件,然后使用 $(LD) -r 把它們鏈接成一個(gè) O_TARGET 或 L_TARGET。O_TARGET 以 .o 結尾,而 L_TARGET 以 .a 結尾。
2.4 子目錄 Makefile
子目錄 Makefile 用來(lái)控制本級目錄以下源代碼的編譯規則。我們通過(guò)一個(gè)例子來(lái)講解子目錄 Makefile 的組成:
#
# Makefile for the linux kernel.
#
# All of the (potential) objects that export symbols.
# This list comes from ‘grep -l EXPORT_SYMBOL *.[hc]’。
export-objs ?。? tc.o
# Object file lists.
obj-y ?。?
obj-m ?。?
obj-n ?。?
obj- ?。?
obj-$(CONFIG_TC) += tc.o
obj-$(CONFIG_ZS) += zs.o
obj-$(CONFIG_VT) += lk201.o lk201-map.o lk201-remap.o
# Files that are both resident and modular: remove from modular.
obj-m ?。? $(filter-out $(obj-y), $(obj-m))
# Translate to Rules.make lists.
L_TARGET ?。? tc.a
L_OBJS ?。? $(sort $(filter-out $(export-objs), $(obj-y)))
LX_OBJS ?。? $(sort $(filter $(export-objs), $(obj-y)))
M_OBJS ?。? $(sort $(filter-out $(export-objs), $(obj-m)))
MX_OBJS ?。? $(sort $(filter $(export-objs), $(obj-m)))
include $(TOPDIR)/Rules.make
a) 注釋
對 Makefile 的說(shuō)明和解釋?zhuān)?開(kāi)始。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- STM32MP157系列教程連載-Linux系統移植篇8:STM32MP1微處理器之Linux內核配置及編譯 0次下載
- STM32MP157 Linux系統移植開(kāi)發(fā)篇8:Linux內核配置方法及編譯 9次下載
- 嵌入式Linux系統移植(Linux內核配置) 13次下載
- 嵌入式Linux開(kāi)發(fā)之內核rtc時(shí)鐘配置 10次下載
- 嵌入式Linux內核編譯 12次下載
- 嵌入式LINUX系統內核和內核模塊調試 9次下載
- Linux系統中EXP命令詳解質(zhì)量匯總 1次下載
- Linux內核配置的網(wǎng)絡(luò )資料說(shuō)明 14次下載
- Linux內核GPIO操作函數的詳解分析 28次下載
- 嵌入式LINUX系統內核和內核模塊調試教程 21次下載
- Linux內核編譯過(guò)程詳解 4次下載
- 《Linux設備驅動(dòng)開(kāi)發(fā)詳解》第4章、Linux內核模塊 0次下載
- linux下網(wǎng)卡配置詳解 0次下載
- 嵌入式Linux內核移植詳解(頂嵌) 19次下載
- 基于嵌入式Linux系統的LCD驅動(dòng)實(shí)現Implementa 28次下載
- 獲取Linux內核源碼的方法 270次閱讀
- T507開(kāi)發(fā)板如何修改和保存內核配置 192次閱讀
- 基于優(yōu)先級調度的嵌入式實(shí)時(shí)操作系統內核詳解(下) 478次閱讀
- Linux系統內核與Linux發(fā)行套件的區別 917次閱讀
- Linux內核系統調用概述及實(shí)現原理 1875次閱讀
- Linux操作系統修改內核參數的三種方法詳細說(shuō)明 1w次閱讀
- Linux:QEMU調試內核的步驟 2841次閱讀
- 深入linux內核架構 Linux內核架構分析解讀 3376次閱讀
- 嵌入式Linux啟動(dòng)時(shí)間優(yōu)化的秘密之三-內核 2247次閱讀
- 一文詳解Linux內核測試現狀 2925次閱讀
- Linux內核與Android的關(guān)系 4371次閱讀
- 基于嵌入式Linux內核的系統設備驅動(dòng)程序開(kāi)發(fā)設計 1031次閱讀
- macOS和Linux的內核之間的區別詳解 5317次閱讀
- Linux內核地址映射模型與Linux內核高端內存詳解 3299次閱讀
- PowerPC平臺Linux的移植(二) 1132次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開(kāi)關(guān)電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統的設計與實(shí)現
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開(kāi)發(fā)板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開(kāi)關(guān)電源設計實(shí)例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書(shū))
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動(dòng)電路設計》 溫德?tīng)栔?zhù)
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會(huì )AVR單片機與C語(yǔ)言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論