婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 探索Linux內(nèi)核:Kconfig的秘密

探索Linux內(nèi)核:Kconfig的秘密

熱門標(biāo)簽:地圖標(biāo)注w是什么方向 地圖標(biāo)注需要提交啥資料入駐 河南省鄭州市地圖標(biāo)注 新鄉(xiāng)人工智能電話機(jī)器人加盟 昆明外呼系統(tǒng) 臨汾電銷機(jī)器人費(fèi)用 福州呼叫中心外呼系統(tǒng)哪家好 七大洲地圖標(biāo)注 400電話申請(qǐng)找哪家公司

深入了解Linux配置/構(gòu)建系統(tǒng)是如何工作的。

自從Linux內(nèi)核代碼遷移到Git之后,Linux內(nèi)核配置/構(gòu)建系統(tǒng)(也稱為Kconfig/kBuild)已經(jīng)存在了很長(zhǎng)時(shí)間。然而,作為支持基礎(chǔ)設(shè)施,它很少受到關(guān)注;即使在日常工作中使用它的內(nèi)核開(kāi)發(fā)人員也從未真正考慮過(guò)它。

為了探索Linux內(nèi)核是如何編譯的,本文將深入研究Kconfig/kBuild內(nèi)部進(jìn)程,解釋.config文件和vmlinux/bzImage文件是如何生成的,并介紹一個(gè)用于依賴性跟蹤的智能技巧。

Kconfig

構(gòu)建內(nèi)核的第一步總是配置。Kconfig幫助使Linux內(nèi)核高度模塊化和可定制。Kconfig為用戶提供了許多配置目標(biāo):

config 使用面向行的程序更新當(dāng)前配置
nconfig 使用基于ncurses菜單的程序更新當(dāng)前配置
menuconfig 使用基于菜單的程序更新當(dāng)前配置
xconfig 利用基于qt的前端更新當(dāng)前配置
gconfig 利用基于GTK+的前端更新當(dāng)前配置
oldconfig 使用提供的.config作為基礎(chǔ)更新當(dāng)前配置
localmodconfig 更新未加載的當(dāng)前配置禁用模塊
localyesconfig 更新當(dāng)前配置,將本地MODS轉(zhuǎn)換為核心
defconfig 從Arch提供的Defconfig中獲得默認(rèn)配置的新配置
Savedefconfig 將當(dāng)前配置保存為./defconfig(最小配置)
allnoconfig 使用“no”回答所有選項(xiàng)的新配置
allyesconfig 新配置,在該配置中,所有選項(xiàng)都以“是”接受
allmodconfig 在可能的情況下選擇新的配置模塊
alldefconfig 將所有符號(hào)設(shè)置為默認(rèn)值的新配置
randconfig 具有對(duì)所有選項(xiàng)的隨機(jī)答案的新配置
listnewconfig 列出新選項(xiàng)
olddefconfig 與oldconfig相同,但在不提示的情況下將新符號(hào)設(shè)置為默認(rèn)值
kvmconfig 為kvm客戶端內(nèi)核支持啟用其他選項(xiàng)
xenconfig 啟用Xen dom0和來(lái)賓內(nèi)核支持的其他選項(xiàng)
tinyconfig 配置盡可能小的內(nèi)核

我認(rèn)為menuconfig是這些目標(biāo)中最受歡迎的。目標(biāo)由不同的主機(jī)程序進(jìn)行處理,這些程序由內(nèi)核提供,并在內(nèi)核構(gòu)建過(guò)程中生成。一些目標(biāo)有一個(gè)GUI(為了用戶的方便),而大多數(shù)沒(méi)有。與kconfig相關(guān)的工具和源代碼主要位于scripts/kconfig/在內(nèi)核源代碼中。我們可以從scripts/kconfig/makefile,有幾個(gè)主機(jī)程序,包括CONF, mconf,和nconf。除了CONF,它們每個(gè)都負(fù)責(zé)基于GUI的配置目標(biāo)之一,因此,CONF和他們中的大多數(shù)人打交道。

從邏輯上講,Kconfig的基礎(chǔ)結(jié)構(gòu)有兩個(gè)部分:一個(gè)實(shí)現(xiàn)了新語(yǔ)言要定義配置項(xiàng)(請(qǐng)參閱內(nèi)核源代碼下的Kconfig文件),而其他配置項(xiàng)則解析Kconfig語(yǔ)言并處理配置操作。

大多數(shù)配置目標(biāo)的內(nèi)部流程大致相同(如下所示):

注意,所有配置項(xiàng)都有一個(gè)默認(rèn)值。

第一步讀取源根下的Kconfig文件以構(gòu)造初始配置數(shù)據(jù)庫(kù);然后根據(jù)此優(yōu)先級(jí)讀取現(xiàn)有配置文件來(lái)更新初始數(shù)據(jù)庫(kù):

  • .config
  • /lib/Module/$(shell,uname-r)/.config
  • /etc/kernel-config
  • /boot/config-$(shell,uname-r)
  • ARCH_DEFCONFIG
  • ARCH/$(ARCH)/Defconfig

如果您正在進(jìn)行基于GUI的配置,則通過(guò)menuconfig或基于命令行的配置oldconfig,數(shù)據(jù)庫(kù)將根據(jù)您的自定義進(jìn)行更新。最后,將配置數(shù)據(jù)庫(kù)轉(zhuǎn)儲(chǔ)到.config文件中。

但是.config文件不是內(nèi)核構(gòu)建的最終素材;這就是為什么syncconfig目標(biāo)存在。syncconfig以前是一個(gè)名為silentoldconfig,但是它不像舊名字說(shuō)的那樣,所以它被重命名了。此外,由于它是內(nèi)部使用(而不是為用戶),它被從列表中刪除。

下面是一個(gè)例子syncconfig作用:

syncconfig接受.config作為輸入并輸出許多其他文件,這些文件分為三類:

auto.conf & tristate.conf用于生成文件文本處理。例如,您可能在組件的makefile中看到這樣的語(yǔ)句:

obj-$(CONFIG_GENERIC_CALIBRATE_DELAY) += calibrate.o

autoconf.h在C語(yǔ)言源文件中使用。

空頭文件include/config/用于在kbuild期間進(jìn)行配置依賴項(xiàng)跟蹤,下面將對(duì)此進(jìn)行解釋。

配置之后,我們將知道哪些文件和代碼段沒(méi)有編譯。

KBuild

組件式建筑,稱為遞歸制作,是GNU的一種常見(jiàn)方式。制作,使管理一個(gè)大型項(xiàng)目。KBuild是遞歸make的一個(gè)很好的例子。通過(guò)將源文件劃分為不同的模塊/組件,每個(gè)組件都由自己的Makefile管理。當(dāng)您開(kāi)始構(gòu)建時(shí),頂級(jí)Makefile按正確的順序調(diào)用每個(gè)組件的makefile,構(gòu)建組件,并將它們收集到最終的執(zhí)行程序中。

KBuild指的是不同類型的makefile:

  • Makefile位于源根中的頂部makefile。
  • .config是內(nèi)核配置文件。
  • ARCH/$(ARCH)/Makefile是拱形Makefile,這是對(duì)頂部makefile的補(bǔ)充。
  • scripts/Makefile*描述所有kbuild makefile的通用規(guī)則。
  • 最后,大約有500個(gè)Kbuildmakefiles.

頂部的makefile包含archmakefile,讀取.config文件,進(jìn)入子目錄,調(diào)用制作,使中定義的例程的幫助下實(shí)現(xiàn)每個(gè)組件的makefile。scripts/Makefile*,構(gòu)建每個(gè)中間對(duì)象,并將所有中間對(duì)象鏈接到vmlinux。核心文件Documentation/kbuild/makefiles.txt描述這些制作文件的所有方面。

例如,讓我們看看在x86-64上如何生成vmlinux:

(插圖是根據(jù)理查德·Y·史蒂文(Richard Y.Steven)的博客。經(jīng)提交人許可后予以更新和使用。

所有.o進(jìn)入vmlinux的文件首先進(jìn)入它們自己的built-in.a,這是通過(guò)變量表示的。KBUILD_VMLINUX_INIT, KBUILD_VMLINUX_Main, KBUILD_VMLINUX_LIBS,然后收集到vmlinux文件中。

看看如何在Linux內(nèi)核中實(shí)現(xiàn)遞歸make,并借助簡(jiǎn)化的Makefile代碼:

# In top Makefile
vmlinux: scripts/link-vmlinux.sh $(vmlinux-deps)
        +$(call if_changed,link-vmlinux)
# Variable assignments
vmlinux-deps := $(KBUILD_LDS) $(KBUILD_VMLINUX_INIT) $(KBUILD_VMLINUX_MAIN) $(KBUILD_VMLINUX_LIBS)
export KBUILD_VMLINUX_INIT := $(head-y) $(init-y)
export KBUILD_VMLINUX_MAIN := $(core-y) $(libs-y2) $(drivers-y) $(net-y) $(virt-y)
export KBUILD_VMLINUX_LIBS := $(libs-y1)
export KBUILD_LDS     := arch/$(SRCARCH)/kernel/vmlinux.lds
init-y     := init/
drivers-y    := drivers/ sound/ firmware/
net-y      := net/
libs-y     := lib/
core-y     := usr/
virt-y     := virt/
# Transform to corresponding built-in.a
init-y     := $(patsubst %/, %/built-in.a, $(init-y))
core-y     := $(patsubst %/, %/built-in.a, $(core-y))
drivers-y    := $(patsubst %/, %/built-in.a, $(drivers-y))
net-y      := $(patsubst %/, %/built-in.a, $(net-y))
libs-y1     := $(patsubst %/, %/lib.a, $(libs-y))
libs-y2     := $(patsubst %/, %/built-in.a, $(filter-out %.a, $(libs-y)))
virt-y     := $(patsubst %/, %/built-in.a, $(virt-y))
# Setup the dependency. vmlinux-deps are all intermediate objects, vmlinux-dirs
# are phony targets, so every time comes to this rule, the recipe of vmlinux-dirs
# will be executed. Refer "4.6 Phony Targets" of `info make`
$(sort $(vmlinux-deps)): $(vmlinux-dirs) ;
# Variable vmlinux-dirs is the directory part of each built-in.a
vmlinux-dirs  := $(patsubst %/,%,$(filter %/, $(init-y) $(init-m) \

           $(core-y) $(core-m) $(drivers-y) $(drivers-m) \

           $(net-y) $(net-m) $(libs-y) $(libs-m) $(virt-y)))
# The entry of recursive make
$(vmlinux-dirs):
        $(Q)$(MAKE) $(build)=$@ need-builtin=1

遞歸的配方擴(kuò)展,例如:

make -f scripts/Makefile.build obj=init need-builtin=1

這意味著make將進(jìn)入scripts/Makefile.build繼續(xù)建造每一個(gè)built-in.a。在.的幫助下scripts/link-vmlinux.sh,vmlinux文件最終位于源根下。

理解vmlinux與bzImage

許多Linux內(nèi)核開(kāi)發(fā)人員可能不清楚vmlinux和bzImage之間的關(guān)系。例如,以下是它們?cè)趚86-64中的關(guān)系:

源根vmlinux被剝離、壓縮、放入piggy.S,然后將其他對(duì)等對(duì)象鏈接到arch/x86/boot/compressed/vmlinux。同時(shí),下面生成一個(gè)名為setup.bin的文件arch/x86/boot。可能有一個(gè)包含重定位信息的可選的第三個(gè)文件,具體取決于config_x86_RELOCS.

一個(gè)名為build由內(nèi)核提供,將這兩個(gè)(或三個(gè))部分構(gòu)建到最終的bzImage文件中。

依賴跟蹤

KBuild跟蹤三種依賴關(guān)系:

  1. 所有的前提文件(*.c和*.h)
  2. CONFIG_在所有先決條件文件中使用的選項(xiàng)
  3. 用于編譯目標(biāo)的命令行依賴關(guān)系。

第一個(gè)很容易理解,但是第二個(gè)和第三個(gè)呢??jī)?nèi)核開(kāi)發(fā)人員經(jīng)常看到這樣的代碼片段:

#ifdef CONFIG_SMP
__boot_cpu_id = cpu;
#endif

什么時(shí)候CONFIG_SMP更改后,這段代碼應(yīng)該重新編譯。編譯源文件的命令行也很重要,因?yàn)椴煌拿钚锌赡軐?dǎo)致不同的對(duì)象文件。

當(dāng).C文件通過(guò)#include指令,您需要編寫這樣的規(guī)則:

main.o: defs.h
recipe...

在管理一個(gè)大型項(xiàng)目時(shí),您需要很多這樣的規(guī)則;所有這些規(guī)則都會(huì)乏味。幸運(yùn)的是,大多數(shù)現(xiàn)代C編譯器可以通過(guò)查看#include源文件中的行。對(duì)于GNU編譯器集合(GCC),只需添加一個(gè)命令行參數(shù):-MD depfile

# In scripts/Makefile.lib
c_flags    = -Wp,-MD,$(depfile) $(NOSTDINC_FLAGS) $(LINUXINCLUDE)   \

         -include $(srctree)/include/linux/compiler_types.h    \

         $(__c_flags) $(modkern_cflags)              \

         $(basename_flags) $(modname_flags)

這將生成一個(gè).D文件的內(nèi)容如下:

init_task.o: init/init_task.c include/linux/kconfig.h \

include/generated/autoconf.h include/linux/init_task.h \

include/linux/rcupdate.h include/linux/types.h \

...

然后主機(jī)程序fixdep通過(guò)獲取其他兩個(gè)依賴項(xiàng)來(lái)處理其他兩個(gè)依賴項(xiàng)。depfile命令行作為輸入,然后以makefile語(yǔ)法輸出.cmd文件,它記錄目標(biāo)的命令行和所有先決條件(包括配置)。看起來(lái)是這樣的:

# The command line used to compile the target
cmd_init/init_task.o := gcc -Wp,-MD,init/.init_task.o.d -nostdinc ...
...
# The dependency files
deps_init/init_task.o := \

$(wildcard include/config/posix/timers.h) \

$(wildcard include/config/arch/task/struct/on/stack.h) \

$(wildcard include/config/thread/info/in/task.h) \

...
 include/uapi/linux/types.h \

 arch/x86/include/uapi/asm/types.h \

 include/uapi/asm-generic/types.h \

...

在遞歸生成過(guò)程中將包含一個(gè).cmd文件,提供所有依賴項(xiàng)信息,并幫助決定是否重新構(gòu)建目標(biāo)。

這背后的秘密是,F(xiàn)ixdep將解析depfile(.d文件),然后解析其中的所有依賴文件,搜索所有config_string的文本,將它們轉(zhuǎn)換為相應(yīng)的空頭文件,并將它們添加到目標(biāo)的先決條件中。每次配置更改時(shí),相應(yīng)的空頭文件也將被更新,因此kbuild可以檢測(cè)到該更改并重新構(gòu)建依賴于它的目標(biāo)。因?yàn)檫€記錄了命令行,所以很容易比較最后的編譯參數(shù)和當(dāng)前的編譯參數(shù)。

展望未來(lái)

Kconfig/kbuild很長(zhǎng)一段時(shí)間沒(méi)有變化,直到新的維護(hù)者山田正一郎(Masahiro Yamada)在2017年初加入,現(xiàn)在KBuild又在積極發(fā)展。如果你很快看到了與本文不同的東西,不要感到驚訝。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

標(biāo)簽:鎮(zhèn)江 海口 四川 烏海 股票 岳陽(yáng) 臨沂 紅河

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《探索Linux內(nèi)核:Kconfig的秘密》,本文關(guān)鍵詞  探索,Linux,內(nèi)核,Kconfig,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《探索Linux內(nèi)核:Kconfig的秘密》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于探索Linux內(nèi)核:Kconfig的秘密的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产日韩精品久久久| 三级精品在线观看| 欧美巨大另类极品videosbest | 国产精品1区2区3区在线观看| 亚洲欧洲在线观看av| 日韩欧美国产1| 91久久精品一区二区三| 亚洲国产精品麻豆| 欧美蜜桃一区二区三区| 成人精品国产免费网站| 日本不卡一区二区三区| 日韩国产精品大片| 亚洲国产精品久久久久婷婷884| 国产精品污www在线观看| 日韩欧美一区二区视频| 91国偷自产一区二区三区成为亚洲经典 | 日本不卡的三区四区五区| 亚洲欧洲www| 国产日产欧美精品一区二区三区| 欧美美女一区二区在线观看| 色综合咪咪久久| 成人一道本在线| 韩国三级中文字幕hd久久精品| 亚洲成在人线在线播放| 一区二区三区视频在线看| 国产精品色一区二区三区| 久久美女高清视频| 日韩你懂的在线观看| 欧美精品自拍偷拍动漫精品| 91黄色免费版| 色婷婷亚洲综合| 99麻豆久久久国产精品免费| 成人免费视频视频| 成人在线视频一区| 国产精品系列在线播放| 久久精品噜噜噜成人av农村| 免费看日韩a级影片| 青青草原综合久久大伊人精品| 日韩成人一级片| 日本va欧美va欧美va精品| 日韩avvvv在线播放| 日本一不卡视频| 蜜桃av一区二区三区| 蜜臀精品一区二区三区在线观看 | 91丝袜呻吟高潮美腿白嫩在线观看| 国产99久久久国产精品潘金网站| 极品少妇xxxx精品少妇偷拍| 久久99九九99精品| 国产一区二区久久| 国产精品亚洲一区二区三区在线| 国产一区二区三区不卡在线观看 | 亚洲激情欧美激情| 亚洲一卡二卡三卡四卡无卡久久| 亚洲主播在线播放| 图片区小说区区亚洲影院| 首页欧美精品中文字幕| 免费精品视频在线| 国产福利一区二区三区视频 | 懂色av一区二区三区蜜臀| jizz一区二区| 在线观看国产一区二区| 欧美乱熟臀69xxxxxx| 欧美mv和日韩mv的网站| 久久久精品影视| 一区二区三区四区在线免费观看 | 91视频免费播放| 欧美影院精品一区| 欧美美女视频在线观看| 久久蜜桃香蕉精品一区二区三区| 国产精品久久久久久久久晋中| 一区二区三区日韩在线观看| 午夜欧美在线一二页| 精品无码三级在线观看视频| 成人中文字幕合集| 欧美日本韩国一区二区三区视频| 精品美女在线播放| 亚洲天堂2016| 免费在线观看一区二区三区| 国产91丝袜在线播放| 在线精品视频一区二区| 日韩午夜在线观看视频| 国产精品理论片| 亚洲成人av一区二区三区| 国产精品91一区二区| 在线一区二区三区做爰视频网站| 日韩午夜精品电影| 国产精品国产自产拍在线| 香蕉成人伊视频在线观看| 国产精品一区二区果冻传媒| 欧美视频完全免费看| 久久综合99re88久久爱| 亚洲一区二区不卡免费| 粉嫩在线一区二区三区视频| 欧美精品久久99久久在免费线| 久久精品亚洲麻豆av一区二区| 亚洲电影第三页| av一区二区三区四区| 91麻豆精品国产自产在线观看一区 | 国产精品一区专区| 欧美日韩高清一区二区不卡 | 久久99精品久久久久久动态图| 一本久久精品一区二区| 亚洲精品一区二区在线观看| 亚洲综合清纯丝袜自拍| 风间由美中文字幕在线看视频国产欧美 | 午夜av电影一区| 欧美三级日韩三级| 精品少妇一区二区三区视频免付费| 综合av第一页| 国产一区二区三区四| 91精品啪在线观看国产60岁| 一区二区三区国产精华| av中文字幕一区| 精品乱人伦小说| 蜜臀久久久久久久| 欧美精品在线观看播放| 亚洲综合久久久| 99天天综合性| 国产片一区二区| 国内一区二区视频| 精品久久久久一区| 久久精品国产一区二区三区免费看| 欧美性猛交xxxx黑人交| 亚洲色图清纯唯美| 成人免费高清在线| 国产片一区二区三区| 国产一区二区导航在线播放| 日韩精品中文字幕一区| 日产精品久久久久久久性色| 欧美日韩在线电影| 一区二区三区久久| 波多野结衣精品在线| 国产精品成人一区二区艾草| 欧美午夜免费电影| 成人欧美一区二区三区黑人麻豆 | 国产一区二区三区电影在线观看 | 欧美日韩美少妇| 亚洲乱码国产乱码精品精小说| 成人美女视频在线观看| 欧美精品一区二区三区在线| 午夜电影久久久| 欧美大片在线观看一区| 日日夜夜精品视频天天综合网| 欧美日韩一区 二区 三区 久久精品| 国产精品美女一区二区三区 | 久久久www成人免费毛片麻豆| 日韩综合小视频| 欧美一区二区三区四区五区| 丝袜美腿高跟呻吟高潮一区| 91电影在线观看| 夜夜精品浪潮av一区二区三区| 国产精品一区二区免费不卡 | 欧美亚日韩国产aⅴ精品中极品| 亚洲美女少妇撒尿| 91视频精品在这里| 亚洲人成7777| 在线视频你懂得一区| 亚洲美女电影在线| 在线观看www91| 一区二区三区在线免费观看| 国产成人精品午夜视频免费| 亚洲欧美成aⅴ人在线观看 | 欧美综合亚洲图片综合区| 亚洲精品成人精品456| 欧美日韩国产一级片| 亚洲午夜视频在线| 69堂成人精品免费视频| 免费成人小视频| 久久久久久综合| 欧美在线观看禁18| 日韩高清国产一区在线| 精品国产乱码久久久久久闺蜜| 国产精品小仙女| 亚洲香肠在线观看| 欧美一区二区网站| 极品美女销魂一区二区三区| 中文文精品字幕一区二区| 欧美丝袜丝交足nylons图片| 国产毛片精品一区| 国产精品福利一区二区三区| 精品视频资源站| 国产又粗又猛又爽又黄91精品| 久久亚洲一区二区三区四区| av影院午夜一区| 亚洲影视在线观看| 日韩欧美一区中文| 精品免费99久久| 91亚洲国产成人精品一区二三| 免费人成在线不卡| 亚洲欧洲一区二区三区| 欧美精品电影在线播放| 国产福利一区二区三区视频在线| 五月综合激情婷婷六月色窝| 国产视频一区在线播放| 91国偷自产一区二区三区成为亚洲经典| 美腿丝袜一区二区三区| 夜夜精品浪潮av一区二区三区| 精品国产乱码久久久久久蜜臀| 91黄色免费看| 国内欧美视频一区二区|