剖析boot.img的制作流程
★★★ 友情鏈接 : 個人博客導(dǎo)讀首頁—點擊此處 ★★★
當用戶敲擊了make bootimage時,我看看是如何工作的
在build/core/main.mk中,我們發(fā)現(xiàn)bootimage依賴INSTALLED_BOOTIMAGE_TARGET
隨后轉(zhuǎn)到build/core/Makefile中,我們可以看到INSTALLED_BOOTIMAGE_TARGET其實就是boot.img,其依賴關(guān)系如下
INSTALLED_BOOTIMAGE_TARGET := $(PRODUCT_OUT)/boot.img$(INSTALLED_BOOTIMAGE_TARGET): $(MKBOOTIMG) $(INTERNAL_BOOTIMAGE_FILES)$(call pretty,"Target boot image: $@")$(hide) $(MKBOOTIMG) $(INTERNAL_BOOTIMAGE_ARGS) $(INTERNAL_MKBOOTIMG_VERSION_ARGS) $(BOARD_MKBOOTIMG_ARGS) --output $@$(hide) $(call assert-max-image-size,$@,$(BOARD_BOOTIMAGE_PARTITION_SIZE))看看簡單吧,INSTALLED_BOOTIMAGE_TARGET依賴兩個目標:MKBOOTIMG和INTERNAL_BOOTIMAGE_FILES。
INTERNAL_BOOTIMAGE_FILES是真正的linux kernel,對應(yīng)的也就是zImage,MKBOOTIMG其實就是mkbootimg工具。
當著兩個目標生成后(也就是工具已在out/host下生成了、linux kernel意見編譯Ok了),隨后會調(diào)用下面的命令,進行打包boot.img:
(1)MKBOOTIMG=$(HOST_OUT_EXECUTABLES)/mkbootimg 是制作boot.img的工具
(2)INTERNAL_BOOTIMAGE_ARGS 是制作boot.img的參數(shù),它是一堆參數(shù)的集合,這里我們只看我們經(jīng)常使用的:
也就是說,如果系統(tǒng)不帶system_as_root功能(android9.0以前的基本都不帶,android9.0后的google要求必須帶),則會將ramdisk也加入到 INTERNAL_BOOTIMAGE_ARGS. 另外一個INTERNAL_KERNEL_CMDLINE對應(yīng)的則是cmdline
由此我們就明白了,ramdisk到底是在system.img中,還是在boot.img中?(答:以往ramdisk都是在boot.img中,在開啟了system_as_root功能以后,就在system.img中了),所以當你修改了device下面的init.xxxx.rc后,是該編譯bootimage還是編譯systemimg,這里就可以理解了吧
(3)BOARD_MKBOOTIMG_ARGS //google預(yù)留接口
在android默認release的版本中,這個參數(shù)其實是為空的,是芯片上在適配android代碼時,有時會改變或定制boot.img的需求,比如android9.0要求將boot.img的header_version改為1(不然vts不過), 查閱google文檔,需要在制作boot.img的命令行中,追加一個參數(shù)header_version=1,這里芯片上就可以把這個參數(shù)填入到BOARD_MKBOOTIMG_ARGS變量中
Q & A:
boot.img是如何制作的?
答:boot.img是通過mkbootimg工具,將linux kernel的binary zImage、內(nèi)核的cmdline、ramdisk、dtbo…等一些信息,打包在了一起,做為boot.img
如有不足,歡迎指教!
總結(jié)
以上是生活随笔為你收集整理的剖析boot.img的制作流程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: System.img是如何打包的
- 下一篇: OTA整包的制作流程(未完)