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

主頁 > 知識庫 > 探索Linux內核:Kconfig的秘密

探索Linux內核:Kconfig的秘密

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

深入了解Linux配置/構建系統是如何工作的。

自從Linux內核代碼遷移到Git之后,Linux內核配置/構建系統(也稱為Kconfig/kBuild)已經存在了很長時間。然而,作為支持基礎設施,它很少受到關注;即使在日常工作中使用它的內核開發人員也從未真正考慮過它。

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

Kconfig

構建內核的第一步總是配置。Kconfig幫助使Linux內核高度模塊化和可定制。Kconfig為用戶提供了許多配置目標:

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

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

從邏輯上講,Kconfig的基礎結構有兩個部分:一個實現了新語言要定義配置項(請參閱內核源代碼下的Kconfig文件),而其他配置項則解析Kconfig語言并處理配置操作。

大多數配置目標的內部流程大致相同(如下所示):

注意,所有配置項都有一個默認值。

第一步讀取源根下的Kconfig文件以構造初始配置數據庫;然后根據此優先級讀取現有配置文件來更新初始數據庫:

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

如果您正在進行基于GUI的配置,則通過menuconfig或基于命令行的配置oldconfig,數據庫將根據您的自定義進行更新。最后,將配置數據庫轉儲到.config文件中。

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

下面是一個例子syncconfig作用:

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

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

obj-$(CONFIG_GENERIC_CALIBRATE_DELAY) += calibrate.o

autoconf.h在C語言源文件中使用。

空頭文件include/config/用于在kbuild期間進行配置依賴項跟蹤,下面將對此進行解釋。

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

KBuild

組件式建筑,稱為遞歸制作,是GNU的一種常見方式。制作,使管理一個大型項目。KBuild是遞歸make的一個很好的例子。通過將源文件劃分為不同的模塊/組件,每個組件都由自己的Makefile管理。當您開始構建時,頂級Makefile按正確的順序調用每個組件的makefile,構建組件,并將它們收集到最終的執行程序中。

KBuild指的是不同類型的makefile:

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

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

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

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

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

看看如何在Linux內核中實現遞歸make,并借助簡化的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

遞歸的配方擴展,例如:

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

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

理解vmlinux與bzImage

許多Linux內核開發人員可能不清楚vmlinux和bzImage之間的關系。例如,以下是它們在x86-64中的關系:

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

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

依賴跟蹤

KBuild跟蹤三種依賴關系:

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

第一個很容易理解,但是第二個和第三個呢?內核開發人員經??吹竭@樣的代碼片段:

#ifdef CONFIG_SMP
__boot_cpu_id = cpu;
#endif

什么時候CONFIG_SMP更改后,這段代碼應該重新編譯。編譯源文件的命令行也很重要,因為不同的命令行可能導致不同的對象文件。

當.C文件通過#include指令,您需要編寫這樣的規則:

main.o: defs.h
recipe...

在管理一個大型項目時,您需要很多這樣的規則;所有這些規則都會乏味。幸運的是,大多數現代C編譯器可以通過查看#include源文件中的行。對于GNU編譯器集合(GCC),只需添加一個命令行參數:-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)

這將生成一個.D文件的內容如下:

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 \

...

然后主機程序fixdep通過獲取其他兩個依賴項來處理其他兩個依賴項。depfile命令行作為輸入,然后以makefile語法輸出.cmd文件,它記錄目標的命令行和所有先決條件(包括配置)??雌饋硎沁@樣的:

# 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 \

...

在遞歸生成過程中將包含一個.cmd文件,提供所有依賴項信息,并幫助決定是否重新構建目標。

這背后的秘密是,Fixdep將解析depfile(.d文件),然后解析其中的所有依賴文件,搜索所有config_string的文本,將它們轉換為相應的空頭文件,并將它們添加到目標的先決條件中。每次配置更改時,相應的空頭文件也將被更新,因此kbuild可以檢測到該更改并重新構建依賴于它的目標。因為還記錄了命令行,所以很容易比較最后的編譯參數和當前的編譯參數。

展望未來

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

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽:鎮江 四川 烏海 股票 岳陽 臨沂 紅河

巨人網絡通訊聲明:本文標題《探索Linux內核:Kconfig的秘密》,本文關鍵詞  探索,Linux,內核,Kconfig,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《探索Linux內核:Kconfig的秘密》相關的同類信息!
  • 本頁收集關于探索Linux內核:Kconfig的秘密的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲卡通欧美制服中文| 亚洲第一综合色| 亚洲宅男天堂在线观看无病毒| 国产成人av在线影院| 久久亚洲精华国产精华液| 另类欧美日韩国产在线| 国产亚洲制服色| 午夜精品成人在线视频| 波多野结衣中文字幕一区| 中文字幕第一页久久| 国产91精品一区二区麻豆亚洲| 国产片一区二区三区| 91蝌蚪porny成人天涯| 一区二区三区日韩| 日韩视频在线你懂得| 国产精品一品视频| 亚洲日本青草视频在线怡红院 | 成人午夜免费视频| 一区二区三区四区高清精品免费观看| 欧美日韩国产经典色站一区二区三区| 精品一区二区三区av| 国产精品二三区| 欧美一区二区三区系列电影| 成人自拍视频在线观看| 亚洲永久免费视频| 国产亚洲短视频| 欧美日韩1区2区| av毛片久久久久**hd| 老司机一区二区| 亚洲欧美一区二区三区国产精品| 日韩免费高清电影| 欧美亚洲一区二区在线观看| 国产一区二区三区国产| 香蕉影视欧美成人| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 欧美亚洲尤物久久| 韩国成人精品a∨在线观看| 亚洲人成网站影音先锋播放| 精品国产乱码久久| 91豆麻精品91久久久久久| 福利电影一区二区| 精品综合免费视频观看| 日本少妇一区二区| 亚洲图片欧美一区| 最新不卡av在线| 国产欧美视频一区二区三区| 91精品国产综合久久香蕉麻豆 | 欧美一级免费大片| 91网站视频在线观看| 国产精品一区二区久激情瑜伽| 日韩精彩视频在线观看| 亚洲综合在线第一页| 国产精品日产欧美久久久久| 精品成人佐山爱一区二区| 日韩亚洲欧美综合| 91精品综合久久久久久| 91精品午夜视频| 欧美一区二视频| 91精品国模一区二区三区| 91精品国产综合久久香蕉麻豆| 欧美三级三级三级| 欧美巨大另类极品videosbest | 国产精品中文字幕欧美| 久草中文综合在线| 激情五月激情综合网| 国模套图日韩精品一区二区| 久久精工是国产品牌吗| 国产一区二区0| 成人午夜看片网址| 成人av网址在线观看| 97aⅴ精品视频一二三区| 在线视频国产一区| 欧美日韩亚洲丝袜制服| 日韩欧美美女一区二区三区| 久久一夜天堂av一区二区三区| 国产无人区一区二区三区| 欧美国产成人精品| 亚洲日本成人在线观看| 五月天激情小说综合| 精品无人码麻豆乱码1区2区| 国产精品自拍毛片| 99久久99久久精品国产片果冻 | 在线电影一区二区三区| 日韩一二三四区| 国产情人综合久久777777| 亚洲色图在线视频| 日韩精品午夜视频| 国产91清纯白嫩初高中在线观看| 色综合天天综合在线视频| 7777精品伊人久久久大香线蕉经典版下载 | 日韩av午夜在线观看| 国精产品一区一区三区mba视频| 粉嫩一区二区三区在线看| 在线观看www91| 久久综合久色欧美综合狠狠| 亚洲男人都懂的| 精品一区二区久久久| 色婷婷亚洲一区二区三区| 精品国产免费人成在线观看| 亚洲欧美视频在线观看| 国内精品国产成人| 欧美精品日韩一区| 亚洲欧洲国产日韩| 国内一区二区在线| 欧美精品亚洲二区| 中文字幕一区日韩精品欧美| 美女脱光内衣内裤视频久久网站| av电影天堂一区二区在线观看| 欧美高清视频一二三区| 亚洲日本一区二区三区| 国产美女娇喘av呻吟久久| 在线欧美小视频| 亚洲国产精品精华液ab| 久久爱另类一区二区小说| 91国产免费看| 国产精品国产自产拍在线| 国产一区二区主播在线| 7777精品伊人久久久大香线蕉最新版 | 久久先锋影音av| 日韩国产精品91| 91色.com| 日韩毛片精品高清免费| 成人av电影免费观看| wwwwxxxxx欧美| 久久精品99国产国产精| 日韩精品一区二区三区蜜臀| 日韩高清电影一区| 3751色影院一区二区三区| 午夜av一区二区| 欧美精品18+| 亚洲成人黄色小说| 欧美日韩不卡在线| 五月天亚洲精品| 欧美群妇大交群中文字幕| 亚洲一区电影777| 欧美老女人第四色| 日本欧美加勒比视频| 日韩亚洲欧美成人一区| 美女久久久精品| 精品国免费一区二区三区| 国产一区日韩二区欧美三区| 国产日韩视频一区二区三区| 国产福利不卡视频| 国产精品福利一区| 在线看国产一区| 日韩一区欧美二区| 精品三级在线看| 国产精品一区2区| 中文字幕在线不卡国产视频| 色婷婷久久久综合中文字幕| 亚洲自拍都市欧美小说| 91精品国产综合久久久蜜臀粉嫩| 美腿丝袜亚洲三区| 国产日韩欧美综合在线| 色婷婷av一区二区三区gif | 国产精品综合视频| 亚洲国产高清aⅴ视频| 色综合久久综合网97色综合| 亚洲第一久久影院| 精品国产伦理网| av中文字幕不卡| 亚洲成av人影院| 久久综合狠狠综合| 色婷婷综合久久久久中文一区二区 | 99国产精品久久久久久久久久久| 一区二区三区中文在线观看| 欧美精品123区| 国产成人av电影在线观看| 亚洲乱码国产乱码精品精的特点 | 日韩电影免费在线看| 久久久国产午夜精品| 日本国产一区二区| 国产呦萝稀缺另类资源| 18涩涩午夜精品.www| 欧美丰满美乳xxx高潮www| 国产精品91一区二区| 亚洲大片精品永久免费| 2023国产精品| 欧美午夜电影在线播放| 国产麻豆9l精品三级站| 亚洲高清一区二区三区| 中文在线免费一区三区高中清不卡| 欧美三区在线视频| 成人高清视频免费观看| 日本欧美一区二区三区乱码| 在线观看亚洲精品视频| 亚洲精品老司机| 欧美人伦禁忌dvd放荡欲情| 青青草国产精品亚洲专区无| 亚洲国产经典视频| 欧美精品久久99久久在免费线| 成人av电影免费在线播放| 韩国理伦片一区二区三区在线播放| 亚洲一区日韩精品中文字幕| 欧美精彩视频一区二区三区| 91精品福利在线一区二区三区| 91国产免费看| 91麻豆精东视频| 91蜜桃在线观看| 不卡区在线中文字幕|