在 ubi 之上使用 squashfs 作為根文件系統
我正在嘗試使用壓縮的 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 捲(mtd20
和mtd21
) 創建了兩個 mtd 分區,並在這些設備之上創建了兩個塊設備 (mtdblock20
和mtdblock21
),非常棒。但是,掛載 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 卷並創建一個模擬塊設備。然後你可以用它來掛載你的根目錄。