命令:cat /proc/mtd
dev: size erasesize name
mtd0: 00007000 00010000 "vendor"
mtd1: 00030000 00010000 "IDBlock"
mtd2: 00600000 00010000 "kernel"
mtd3: 00900000 00010000 "rootfs"
大小分别为
"vendor":0x00007000,即十进制的28672,288672/1024=28KB;
"IDBlock":0x00030000,即十进制的196608,196608/1024=192KB;
"kernel":0x00600000,即十进制的6291456,6291456/1024/1024=6MB;
"rootfs":0x00900000,即十进制的9437184,9437184/1024/1024=9MB。
命令:cat /proc/partitions
major minor #blocks name //这里的blocks是以1KB作为单位的?不然下面的和上面怎么对应上。
31 0 28 mtdblock0
31 1 192 mtdblock1
31 2 6144 mtdblock2
31 3 9216 mtdblock3
接下来是RK的setting.ini文件
//文件开始
#Flag 1:skip flag, 2:reserved flag, 4:no partition size flag
#type 0x1:Vendor, 0x2:IDBlock, 0x4:Kernel, 0x8:boot, 0x80000000:data
#PartSize and PartOffset unit by sector
#Gpt_Enable 1:compact gpt, 0:normal gpt
#Backup_Partition_Enable 0:no backup,1:backup
#FILL_BYTE's value is used to fill blank
[System]
FwVersion=15.48.1
Gpt_Enable=
Backup_Partition_Enable=0
Nano=
[UserPart1]
Name=IDBlock
Type=0x2
PartOffset=0x40
PartSize=0x180 //此处一个块是512B,所以IDBlock分区大小是0x180 *512/1024=192KB。
Flag=0x0
File=../rockimg/Image-cvr/rv1108ddr.bin,../rockimg/Image-cvr/rv1108loader.bin
[UserPart2]
Name=kernel
Type=0x4
PartOffset=0x200
PartSize=0x3000 //此处一个块是512B,所以IDBlock分区大小是0x3000 *512/1024/1024=6MB。
Flag=0x0
File=../rockimg/Image-cvr/kernel.img
[UserPart3]
Name=rootfs
Type=0x8
PartOffset=0x3200
PartSize=0x4800 //此处一个块是512B,所以IDBlock分区大小是0x4800 *512/1024/1024=9MB。
Flag=0x0
File=../rockimg/Image-cvr/rootfs.img
# example
#[UserPart4]
#Name=user
#Type=0x80000000
#PartOffset=0x7a00
#PartSize=0x1000
#Flag=0x1
#[UserPart5]
#Name=user1
#Type=0x80000000
#PartOffset=0x8a00
#PartSize=0x0
#Flag=0x5
//文件结束
在上述的配置文件下,编译打包最终生成的固件,内核,文件系统等映像文件就可以计算出来了,并且大小也正确,例如:
内核映像文件,kernel.img:大小应该为6291456Byte,即6MB,但是实际生成的也许只有4.8MB左右,这是因为内核没有全部用完所有的6MB分区。
文件系统映像文件,rootfs.img:大小应该为9437184Byte,即9MB,实际生成的也是9MB,这是因为文件系统的分区全部被使用了。
最终打包生成的固件映像文件,Firmware.img:大小为15990784Byte,即15.25MB(但是在PC上显示经常就是16MB显示)。15.25MB大小是由最后一个分区,此处即文件系统分区的起始地址加上分区大小决定的,(0x3200+0x4800=0x7A00)*512/1024/1024=15.25MB。
所以如果我们想要压缩固件大小,并不是一味的压缩内核或者文件系统,有时也要考虑分区有没有用完,比如说上述这种情况,内核的分区没有用完,我们就可以把内核的分区减小,使文件系统的起始地址向前移,这样所有分区的总和就变小了,也就是固件变小了。