我正在尝试使用压缩的 squashfs ubi 卷作为我的根文件系统。这个想法是有两个 ubi 卷。第一卷包含只读的 squashfs 文件系统。第二卷可调整大小并使用剩余的闪存空间。它包含一个可写的 ubifs 文件系统。这两个 ubi 卷将在启动后使用 overridefs 进行覆盖,以便我拥有一个可写文件系统,能够通过格式化第二个 (ubifs) 卷来恢复到出厂状态。
我知道squashfs仅适用于块设备,因此我使用gluebi驱动程序在ubi卷之上模拟它们(这为每个ubi卷创建mtdx和mtdblockx):
CONFIG_SQUASHFS=y
CONFIG_SQUASHFS_LZO=y
CONFIG_MTD=y
CONFIG_MTD_BLOCK=y
CONFIG_MTD_UBI=y
CONFIG_MTD_UBI_GLUEBI=y
CONFIG_UBIFS_FS=y
这是我用于创建 ubi 映像的 ubinize.conf 文件:
[rom]
mode=ubi
image=rootfs.squashfs-lzo
vol_id=0
vol_type=static
vol_name=ubi_vol_rom
[overlay]
mode=ubi
vol_id=1
vol_type=dynamic
vol_name=ubi_vol_overlay
vol_size=1KiB
vol_flags=autoresize
我正在使用这些 MTD 分区进行测试:
mtd18: 03a00000 00040000 "sys_back"
mtd19: 058c0000 00040000 "system"
我将 ubi 映像刷新到 mtd18 ( sys_back
),将其附加到 ubi,安装生成的 mtdblock,一切都按预期工作,因此我认为我的 ubi 卷和 squashfs 文件系统是正确的。
# ubiattach -m 18
# mount /dev/mtdblock23 /mnt/
# mount
/dev/mtdblock23 on /mnt type squashfs (ro,relatime)
所以,我想尝试一下最终的配置。我将 ubi 映像刷新到 mtd19 ( system
) 并修改了内核参数以包含以下内容:
ubi.mtd=system root=mtd:ubi_vol_rom rootfstype=squashfs
但是挂载根文件系统失败:
[ 3.334908] ubi0: attaching mtd19
[ 3.725841] ubi0: scanning is finished
[ 3.751239] gluebi (pid 1): gluebi_resized: got update notification for unknown UBI device 0 volume 1
[ 3.759465] ubi0: volume 1 ("ubi_vol_overlay") re-sized from 1 to 203 LEBs
[ 3.767111] ubi0: attached mtd19 (name "system", size 88 MiB)
[ 3.772007] ubi0: PEB size: 262144 bytes (256 KiB), LEB size: 253952 bytes
[ 3.778938] ubi0: min./max. I/O unit sizes: 4096/4096, sub-page size 4096
[ 3.785670] ubi0: VID header offset: 4096 (aligned 4096), data offset: 8192
[ 3.792583] ubi0: good PEBs: 355, bad PEBs: 0, corrupted PEBs: 0
[ 3.798604] ubi0: user volume: 2, internal volumes: 1, max. volumes count: 128
[ 3.805807] ubi0: max/mean erase counter: 3/1, WL threshold: 4096, image sequence number: 1328192
[ 3.814929] ubi0: available PEBs: 0, total reserved PEBs: 355, PEBs reserved for bad PEB handling: 40
[ 3.823843] ubi0: background thread "ubi_bgt0d" started, PID 148
[ 4.639909] UBIFS error (pid: 1): cannot open "mtd:ubi_vol_rom", error -22
List of all partitions:
[ 4.647770] 1f00 2560 mtdblock0 (driver?)
[ 4.652783] 1f01 2560 mtdblock1 (driver?)
[ 4.657822] 1f02 22528 mtdblock2 (driver?)
[ 4.662851] 1f03 5120 mtdblock3 (driver?)
[ 4.667886] 1f04 3072 mtdblock4 (driver?)
[ 4.672925] 1f05 1280 mtdblock5 (driver?)
[ 4.677956] 1f06 1536 mtdblock6 (driver?)
[ 4.682994] 1f07 1280 mtdblock7 (driver?)
[ 4.688030] 1f08 9216 mtdblock8 (driver?)
[ 4.693059] 1f09 9216 mtdblock9 (driver?)
[ 4.698094] 1f0a 6400 mtdblock10 (driver?)
[ 4.703214] 1f0b 14336 mtdblock11 (driver?)
[ 4.708339] 1f0c 16896 mtdblock12 (driver?)
[ 4.713458] 1f0d 61440 mtdblock13 (driver?)
[ 4.718582] 1f0e 1280 mtdblock14 (driver?)
[ 4.723701] 1f0f 30720 mtdblock15 (driver?)
[ 4.728826] 1f10 57344 mtdblock16 (driver?)
[ 4.733945] 1f11 127232 mtdblock17 (driver?)
[ 4.739069] 1f12 59392 mtdblock18 (driver?)
[ 4.744228] 1f13 90880 mtdblock19 (driver?)
[ 4.749313] 1f14 26676 mtdblock20 (driver?)
[ 4.754471] 1f15 50344 mtdblock21 (driver?)
[ 4.759552] No filesystem could mount root, tried: ubifs
[ 4.764942] Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(0,0)
[ 5.837944] Rebooting in 5 seconds..
因此,从日志中我可以看出 ubi 按预期附加到 mtd19,调整了第二个分区 ( ubi_vol_overlay
) 的大小,从 ubi 卷创建了两个 mtd 分区(mtd20
和),并在这些 (和)mtd21
之上创建了两个块设备,太棒了。mtdblock20
mtdblock21
然而,挂载squashfs 文件系统( mtdblock20
) 失败。日志显示它尝试使用 as ubifs 进行安装,尽管我明确表示通过参数使用 squashfs rootfstype
。
起初我认为参数中的设备名称可能无法正确解析root=
,因此我尝试使用/dev/mtdblock20
但结果相同。
如何强制内核使用 squashfs 而不是 ubifs 挂载它?
答案1
Squashfs 需要块设备才能运行,因此您需要通过 UBI 进行块模拟。首先确保它在您的内核中启用。
您可以在正在运行的系统上使用 ubiblock 命令对此进行测试。例如,运行ubiblock -c /dev/ubi0_0
将创建 devnode /dev/ubiblock0_0。
一旦有了依赖关系,您就可以在命令行上启用 UBI 块,如下所示:
ubi.mtd=2 ubi.block=0,ubi_vol_rom root=/dev/ubiblock0_0
这将使用名为 ubi_vol_rom 的 UBI 卷并创建一个模拟块设备。然后你可以用它来挂载你的root。