最近想要回顾下之前的一些东西,记录下一些简单但细碎的东西,本章简单从分区表入手随便写写
分区表文件在common\config\partition_nand.xml
0:boot //分区名
7500 //大小必须为block整数,block 为64个page,也可以直接用size_blks
500 //大小必须为block整数,block 为64个page,也可以直接用spad_blks
0
0xFF
0x01
0x00
0xFF
mdm9607-boot.img //固件名称
以一个分区的配置为例,定义了一个boot的分区,大小为7500kb + 500 kb,但是最后是需要取整到block,以128kb block size来看,最后大小为(59+4)*128kb 换算称 16进制就是 007e0000
这个可以从mtd中看到
cat proc/mtd
dev: size erasesize name
mtd0: 00140000 00020000 "sbl"
mtd1: 00140000 00020000 "mibib"
mtd2: 00c00000 00020000 "efs2"
mtd3: 000c0000 00020000 "tz"
mtd4: 00060000 00020000 "rpm"
mtd5: 000a0000 00020000 "aboot"
mtd6: 007e0000 00020000 "boot"
mtd7: 00be0000 00020000 "scrub"
mtd8: 02440000 00020000 "modem"
mtd9: 007c0000 00020000 "recovery"
mtd10: 00180000 00020000 "fota"
mtd11: 00f20000 00020000 "recoveryfs"
mtd12: 00040000 00020000 "sec"
mtd13: 09500000 00020000 "system"
从mtd 文件看到flash分为13个mtd分区。下面简单的介绍下每个分区的含义以及对应的固件
SBL:sbl1.mbn 可以看做软件最开始的入口,固定位置,由芯片固化PBL 跳转
mibib:分区表
efs2:modem efs 文件系统
tz,rpm:trustzone rpm
aboot:lk,ap的BootLoader
boot:kernel mdm9607-boot.img
srub:flash srub 功能的交换区
modem:mp
recovery:升级的kernel,与boot烧录一样的
recoveryfs:升级的ubifs,只有部分必要的功能
system:ubifs
可以看到flash中存储了两个kernel 和两个fs,一个用于正常工作,一个用于升级操作。具体加载选择在lk中通过cmdline传递加载哪个fs。下面就是加载mtd13的正常system fs
rootfstype=ubifs rootflags=bulk_read,sync root=ubi0:rootfs ubi.mtd=13
mdm平台中的fs都是采用的ubifs,包含的三个文件系统:system ,recoveryfs,modem都是ubifs
从上面的cmdline中看到ubi0:rootfs,说明整个ubi0应该有分成不同的volume,具体需要追究下编译过程中的ubifs制作:
apps_proc\oe-core\meta-qcom\recipes\images\mdm-usr-image.inc 中顶一个了最后制作ubifs的命令
ubinize -o ${OUTPUT_FILE_FINAL_UBI} ${UBINIZE_ARGS} ${UBINIZE_CFG}
UBINIZE_CFG 也是在这个文件中生成,可以在生成路径中查询apps_proc/oe-core/build/tmp-glibc/deploy/images/mdm9607/ubinize_system_userdata.cfg,最后的结果为
[sysfs_volume]
mode=ubi
image=apps_proc/oe-core/build/tmp-glibc/deploy/images/mdm9607/mdm-image-mdm9607.ubifs
vol_id=0
vol_type=dynamic
vol_name=rootfs
vol_size=53MiB
[usrfs_volume]
mode=ubi
image=apps_proc/oe-core/build/tmp-glibc/deploy/images/mdm9607/mdm9607-usrfs.ubifs
vol_id=1
vol_type=dynamic
vol_name=usrfs
vol_flags = autoresize
[cache_volume]
mode=ubi
vol_id=2
vol_type=dynamic
vol_name=cachefs
vol_size=75MiB
所以整个ubi0被分成了三个volume,cachefs是空的,所以没有指定image
UBINIZE_ARGS 在apps_proc\oe-core\meta-msm\conf\machine\mdm9607.conf定义
#UBINIZE Args
UBINIZE_ARGS = "-m 2048 -p 131072 -s 2048"
#MKUBIFS Args
MKUBIFS_ARGS = "-m 2048 -e 126976 -c 2146 -F"
#Volume sizes
SYSTEM_VOLUME_SIZE = "53MiB"
CACHE_VOLUME_SIZE = "75MiB"
rootfs 的ubi文件是由meta/classes/image_types.bbclass来生成。一般不需要修改
usrfs 的ubi文件是在mdm-usr-image.inc生成。
那之前cmdline中只讲第一个rootfs挂载为root,其他的两个volume是由apps_proc\oe-core\meta-msm\recipes\startup-scripts\files\mdm9607 find_partitions.sh 脚本在启动时挂载
eval FindAndMountVolume${fstype} usrfs /data
eval FindAndMountVolume${fstype} cachefs /cache
eval FindAndMount${fstype} modem /firmware
modem的ubifs名称为NON-HLOS.ubi,制作ubifs 的配置文件在common\config\my_ubi.ini,相应的mkfs.ubifs,ubinize配置在common\build\contents.xml中
@tool_name -r @src_dir -o @destn_image -m @min_ip_op_unit_size -e @eraseblock_size -c @max_file_system_size_logical_eraseblocks -F
mkfs.ubifs
./bin
2146
126976
2048
NON-HLOS.ubifs
@tool_name -v -o @destn_image -m @min_ip_op_unit_size -p @physical_eraseblock_size -s @sub_page_size ./../config/my_ubi.ini
ubinize
2048
131072
2048
NON-HLOS.ubi