Linux

在 ubi 之上使用 squashfs 作為根文件系統

  • December 27, 2018

我正在嘗試使用壓縮的 squashfs ubi 卷作為我的根文件系統。這個想法是有兩個 ubi 卷。第一卷包含一個只讀的 squashfs 文件系統。第二卷可調整大小並使用剩餘的快閃記憶體空間。它包含一個可寫的 ubifs 文件系統。這兩個 ubi 卷將在啟動後使用 overlayfs 覆蓋,這樣我就有一個可寫文件系統,能夠通過格式化第二個(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 捲(mtd20mtd21) 創建了兩個 mtd 分區,並在這些設備之上創建了兩個塊設備 (mtdblock20mtdblock21),非常棒。

但是,掛載 squashfs 文件系統 ( mtdblock20) 失敗。日誌說它嘗試使用 as ubifs 安裝,即使我明確表示要通過rootfstype參數使用 squashfs。

起初我認為可能是設備名稱在root=參數中沒有正確解析,所以我嘗試使用/dev/mtdblock20但結果相同。

如何強制核心使用 squashfs 而不是 ubifs 掛載它?

Squashfs 需要塊設備才能執行,因此您需要通過 UBI 進行塊模擬。首先確保它在您的核心中啟用。

您可以在正在執行的系統上使用 ubiblock 命令對此進行測試。例如,執行ubiblock -c /dev/ubi0_0將創建 devnode /dev/ubiblock0_0。

一旦你有了依賴,你可以像這樣在 cmdline 上啟用 UBI 塊:

ubi.mtd=2 ubi.block=0,ubi_vol_rom root=/dev/ubiblock0_0

這將使用名為 ubi_vol_rom 的 UBI 卷並創建一個模擬塊設備。然後你可以用它來掛載你的根目錄。

引用自:https://unix.stackexchange.com/questions/455043