[Android]构建boot.img(三):boot.img的生成与结构

在前两篇同一系列的文章中都提到了以下一段语句:

#build/core/Makefile

INTERNAL_BOOTIMAGE_ARGS := \

            --kernel $(INSTALLED_KERNEL_TARGET) \

            --ramdisk $(INSTALLED_RAMDISK_TARGET)

显然,boot.img中包含了Image和ramdisk.img文件,但boot.img中的内容远不只这么多,本文将介绍

boot.img中的其它参数,boot.img的生成以及最终boot.img的组成格式.

INTERNAL_BOOTIMAGE_ARGS还包含以下内容:

1.附加的内核命令行(cmdline): BOARD_KERNEL_CMDLINE

同样在build/core/Makefile中,有以下一段内容(strip起到去除空格的作用):

BOARD_KERNEL_CMDLINE := $(strip $(BOARD_KERNEL_CMDLINE)

ifdef BOARD_KERNEL_CMDLINE

    INTERNAL_BOOTIMAGE_ARGS += --cmdline "$(BOARD_KERNEL_CMDLINE)"

#endif

而BOARD_KERNEL_CMDLINE则在文件device/telechips/tcc88xx-common/BoardConfigCommon.mk中定义:

BOARD_KERNEL_CMDLINE := console=ttyTCC, 115200n8

2.内核加载的基地址,BOARD_KERNEL_BASE

同样在build/core/Makefile中,有以下一段内容:

BOARD_KERNEL_BASE := $(strip $(BOARD_KERNEL_BASE))

ifdef BOARD_KERNEL_BASE

    INTERNAL_BOOTIMAGE_ARGS += --base $(BOARD_KERNEL_BASE)

endif

而BOARD_KERNEL_BASE也在device/telechips/tcc88xx-common/BoardConfigCommon.mk中定义。

BOARD_KERNEL_BASE := 0x40000000

3.映像的页面大小:BOARD_KERNEL_PAGESIZE

同样在build/core/Makefile中,有以下一段内容:

BOARD_KERNEL_PAGESIZE:= $(strip $(BOARD_KERNEL_PAGESIZE))

ifdef BOARD_KERNEL_PAGESIZE

    INTERNAL_BOOTIMAGE_ARGS += --pagesize $(BOARD_KERNEL_PAGESIZE)

endif

BOARD_KERNEL_PAGESIZE 却device/telechips/tcc8800/BoardConfig.mk中定义:

BOARD_KERNEL_PAGESIZE := 8192

剩下的内容就是生成boot.img的关键语句,在 build/core/Makefile中,内容如下:

INSTALLED_BOOTIMAGE_TARGET := $(PRODUCT_OUT)/boot.img

$(INTALLED_BOOTIMAGE_TARGET) : $(MKBOOTIMG) $(INTERNAL_BOOTIMAGE_FILE

      $(hide) $(MKBOOTIMG) $(INTERNAL_BOOTIMAGE_ARGS)  --output $@

到此,我们可以知道 INTERNAL_BOOTIMAGE_ARGS的内容是:

--kernel     out/target/product/tcc8800/kernel 
--ramdisk   out/target/product/tcc8800/ramdisk.img
--cmdline   console=ttyTCC,115200n8
--base 0x40000000  --pagesize 8192

而预知boot.img的格式,必须查看MKBOOTIMG这个程序,其实就是out/host/linux-x86/bin/mkbootimg中的mkbootimg程序。

mkbootimg程序由system/core/mkbootimg工程生成得到,为此我们来看看其中的mkbootimg.c文件,其中有这样一段:

//信息头部分
if(write(fd,&hdr,sizeof(hdr)) != sizeof(hdr)) goto fail;
if(write_padding(fd,pagesize,sizeof(hdr))) goto fail;

//内核部分
if(write(fd,&kernel_data, hdr.kernel_size)!= hdr.kernel_size)
   goto fail;
if(write_padding(fd,pagesize,hdr.kernel_size)) goto fail;

//文件系统部分
if(write(fd,&ramdisk_data,hdr.ramdisk_size)!= hdr.ramdisk_size)
   goto fail;
if(wirte_padding(fd,pagesize,hdr.ramdisk_size)) goto fail;

可见boot.img是由文件头信息,内核数据以及文件系统数据组成,它们之间非页面对齐部分用0填充(可以

查看write_padding的代码),文件头信息的具体结构可以在system/core/mkbootimg/bootimg.h中看到:

struct boot_img_hdr

{

    unsigned char magic[BOOT_MAGIC_SIZE];

    unsigned  kernel_size;

    unsigned  kernel_addr;

    unsigned  ramdisk_size;

    unsigned  ramdisk_addr;

    unsigned  second_size;

    unsigned  second_addr;

    unsigned  tags_addr;

    unsigned  page_size;

    unsigned  unused[2];

    unsigned  char  name[BOOT_NAME_SIZE]

    unsigned  char cmdline[BOOT_ARGS_SIZE]

    unsigned  id[8]; //存放时间戳,校验和,SHA加密等内容

}

其它成员也很明了,由此可知boot.img的大致组成结构了。

-----------------------------------------------------------------------------------------------------------------------------------------------

你可能感兴趣的:([Android]构建boot.img(三):boot.img的生成与结构)