ubi 文件系统加载失败原因记录

Posted 陈富林

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ubi 文件系统加载失败原因记录相关的知识,希望对你有一定的参考价值。

  • 尝试升级 kernel 到 4.4.12版本,然后出现 kernel 加载 ubi 文件系统失败的现象,现象如下

    [    3.152220] ubi0 error: vtbl_check: too large reserved_pebs 1908, good PEBs 1860
    [    3.160054] ubi0 error: vtbl_check: volume table check failed: record 0, error 9
  • 经过查找,是因为 ubi 文件系统制作过大的原因。

    // 修改制作文件系统的脚本
    //  mkubiimg.sh
    #sudo ./mkfs.ubifs  -q -r rootfs -m 2048 -e 126976 -c 2047 -o  ubifs.img -F
    sudo mkfs.ubifs  -q -r rootfs_release -m 2048 -e 126976 -c 1600 -o  ubifs.img -F

    echo mkfs.ubifs over!
    sudo ubinize -o ubi.img -m 2048 -p 128KiB ubinize.cfg
    echo ubinize over!

    sync

    sudo cp ubi.img ~/image -rf 

    sudo rm ubifs.img  ubi.img  -rf 
    sync
    echo make file system ok !

    // vim  ubinize.cfg
    [ubifs]
    mode=ubi
    image=ubifs.img
    vol_id=0
    vol_size=200MiB
    vol_type=dynamic
    vol_name=rootfs
    vol_flags=autoresize
    mkfs.ubifs 参数:
     -F:file-system free space has to be fixed up on first mount
     -q:未知
     -r:build file system from directory DIR
     -m:最小输入输出大小为2KiB(2048bytes),一般为页大小
     -e:逻辑可擦除块大小为124KiB=(每块的页数-2)*页大小=(64-2)*2KiB=124KiB=126976bytes
     -c:最多逻辑可擦除块数目为1600, 这个值是通过 ubinize.cfg 里面的 vol_size=200MiB算出来的, 200M * 1024 / 128K 算出来的。

    ubinize 参数:
    -o:输出文件名
    -m:最小输入输出大小为2KiB(2048bytes),一般为页大小 
    -p:物理可擦出块大小为128KiB=每块的页数*页大小=64*2KiB=128KiB 
    -s:用于UBI头部信息的最小输入输出单元,一般与最小输入输出单元(-m参数)大小一样。

以上是关于ubi 文件系统加载失败原因记录的主要内容,如果未能解决你的问题,请参考以下文章

SoundPool 加载失败

安卓x5内核加载失败怎么办 导致失败的原因是啥呢

格式化并挂载ubi文件系统过程详解

KERNELBASE.dll 啥原因

npm : 无法加载文件 D:softcodeProcess ode ode_global pm.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.micr +(代码片段

加载驱动失败怎么办