关于MTD分区这个概念,我以前一直理解错,就是因为外面都叫他MTD分区,其实还不如说是MTD分割符,因为他只是在内核的一个定义.他并不是严格的分区.目前针对MX28这个平台,来说说怎么调整.
目前来说,我的uImage文件大概是2.5M,这是默认的大小,以后可能通过裁剪更小,也可能通过丰富功能更大,保险起见应该给3M大小.而我的U-Boot,还是会继续使用的,而不用FSL的Bootlets,主要是U-Boot功能强大很多,也没多多少的启动时间,但是功能不会再添加了,估计,大概1.5M,小于1536KB,所以U-Boot分区1536K,U-Boot参数分区512K,内核分配3M吧.这怎么都够了.压缩Boot纯粹是为了多一点后面的空间,毕竟现在的Flash只有128M,后面rootfs里面很多各种功能呢.
首先是U-Boot的修改,在uboot-src/include/configs下,找到自己的板描述文件,比如我的是mx28_evks.c.然后修改MTDPARTS_DEFAULT.参考配置如下:
#define MTDPARTS_DEFAULT "mtdparts=nandflash0:1536k(bootloder),""512k(params),""3m(kernel),""-(rootfs)"
这个意思是,1536K存放Bootloader,512K存放params,就是Bootloader的配置,3M是内核,剩下都给储存分区了.
Linux内核下也是通过mach文件来规范这个分区的,比如我的MX28平台是kernel/linux-2.6.35.3/arch/arm/mach-mx28/device.c 然后看到定义第一分区的字段.我已经改成5 * SZ_1M了,就是5M啦.
static struct gpmi_nfc_platform_data gpmi_nfc_platform_data = { .nfc_version = 1, .boot_rom_version = 1, .clock_name = "gpmi", .platform_init = gpmi_nfc_platform_init, .platform_exit = gpmi_nfc_platform_exit, .min_prop_delay_in_ns = 5, .max_prop_delay_in_ns = 9, .max_chip_count = 2, .boot_area_size_in_bytes = 5 * SZ_1M, .partition_source_types = gpmi_nfc_partition_source_types, .partitions = 0, .partition_count = 0, };
然后把相应文件(u-boot/zImage/uImage)复制到bootlets中.其中zImage是用于升级的内核,也要一致,然后生成几个sb文件.
-rw-r--r-- 1 root root 2.5M 5月 2 14:40 imx28_ivt_linux.sb -rw-r--r-- 1 root root 328K 5月 2 14:40 imx28_ivt_uboot.sb -rw-r--r-- 1 root root 2.5M 5月 2 14:40 imx28_linux.sb -rw-r--r-- 1 root root 328K 5月 2 14:40 imx28_uboot.sb -rw-r--r-- 1 root root 6.1M 5月 2 14:40 updater_ivt.sb -rw-r--r-- 1 root root 6.1M 5月 2 14:40 updater.sb
然后覆盖MfgTool默认的几个sb文件,然后烧写一下,就得到我们新分区的结果.
MX28 U-Boot > mtdparts mtdparts variable not set, see 'help mtdparts' no partitions defined defaults: mtdids : nand0=nandflash0 mtdparts: mtdparts=nandflash0:1536k(bootloder),512k(params),3m(kernel),-(rootfs)
系统内核打印:
----------------------------- NAND Flash Device Information ----------------------------- Manufacturer : Macronix (0xc2) Device Code : 0xf1 Cell Technology : SLC Chip Size : 128 MiB Pages per Block : 64 Page Geometry : 2048+64 ECC Strength : 4 bits ECC Size : 512 B Data Setup Time : 5 ns Data Hold Time : 5 ns Address Setup Time: 20 ns GPMI Sample Delay : 6 ns tREA : Unknown tRLOH : Unknown tRHOH : Unknown Description : ZLGFlash ----------------- Physical Geometry ----------------- Chip Count : 1 Page Data Size in Bytes: 2048 (0x800) Page OOB Size in Bytes : 64 Block Size in Bytes : 131072 (0x20000) Block Size in Pages : 64 (0x40) Chip Size in Bytes : 134217728 (0x8000000) Chip Size in Pages : 65536 (0x10000) Chip Size in Blocks : 1024 (0x400) Medium Size in Bytes : 134217728 (0x8000000) ------------ NFC Geometry ------------ ECC Algorithm : BCH ECC Strength : 8 Page Size in Bytes : 2112 Metadata Size in Bytes : 10 ECC Chunk Size in Bytes: 512 ECC Chunk Count : 4 Payload Size in Bytes : 2048 Auxiliary Size in Bytes: 16 Auxiliary Status Offset: 12 Block Mark Byte Offset : 1999 Block Mark Bit Offset : 0 ----------------- Boot ROM Geometry ----------------- Boot Area Count : 1 Boot Area Size in Bytes : 5242880 (0x500000) Stride Size in Pages : 64 Search Area Stride Exponent: 2 Scanning device for bad blocks Boot area protection is enabled. Creating 2 MTD partitions on "gpmi-nfc-main": 0x000000000000-0x000000500000 : "gpmi-nfc-0-boot" 0x000000500000-0x000008000000 : "gpmi-nfc-general-use"
然后,就是这句,最后数值,我还没搞懂,不是填写123MiB吗?不是的,要看烧写过程时候,提示,剩下用户可配空间是多少,我看到的是108MiB,根据UBIFS有坏块管理.可能实际还不能用这么多.
ubimkvol /dev/ubi0 -n 0 -N rootfs -s 90000000