嵌入式Linux MTD分区调整(MX28)

/ 0评 / 0

关于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

 

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注