NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)

1. 在内核中修改nand MTD分区后出现错误

错误如下:

UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512
UBI error: vtbl_check: volume table check failed: record 0, error 9
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)

以下是我的MTD分区信息:(drivers/mtd/nand/nuc970_nand.c)

NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)

错误分析

我们查看log发现内核mtd初始化是成功的,只是在ubi挂载文件系统部分出现了错误,根据错误log来看应该是文件系统过大,而分配的32M mtd分太小导致的

下图是mtd分区信息,是正确的
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)
查看文件系统的配置(ubinize.cfg)
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)
根据以上的 vol_size 计算出来大小为88M(实际还得加上文件系统本身占用空间),确实是分区小了
然后我们更改mtd分区信息重新编译烧录内核发现可以正常启动
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)

2. 在u-boot环境变量中传入分区大小

修改mtd分区除了可以在内核中直接修改还可以通过u-boot的命令行参数传入,实际上更推荐这种方法,修改更加灵活,不需要修改内核部分

内核中需要做如下修改,打开命令行分区选项
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)
相应修改环境变量文件,烧录环境变量文件即可
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)
烧录
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)

以下是内核启动时的打印信息,与我们配置的一致
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)
NUC972 MTD分区详解(UBI error: vtbl_check: too large reserved_pebs 824, good PEBs 512 错误分析)

3. 总结

实际的分区我们可以根据自己的实际使用情况来分配,如果想要分出一段空间做升级或者烧录别的文件系统,可以通过调整当前根文件系统的大小来新增别的分区