Estou tentando usar um volume compactado do squashfs ubi como meu sistema de arquivos raiz. A ideia é ter dois volumes de ubi. O volume um contém um sistema de arquivos squashfs somente leitura. O volume dois é redimensionável e usa o espaço restante do flash. Ele contém um sistema de arquivos ubifs gravável. Esses dois volumes ubi devem ser sobrepostos usando o overlayfs após a inicialização para que eu tenha um sistema de arquivos gravável com a capacidade de restaurar para o estado de fábrica formatando o segundo volume (ubifs).
Eu sei que o squashfs funciona somente em dispositivos de bloco, então estou usando o driver gluebi para emulá-los sobre os volumes ubi (isso cria mtdx e mtdblockx para cada volume ubi):
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
Aqui está o meu arquivo ubinize.conf para criar a imagem da ubi:
[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
Estou usando essas partições MTD para testes:
mtd18: 03a00000 00040000 "sys_back"
mtd19: 058c0000 00040000 "system"
Eu mostrei a imagem da ubi para o mtd18 ( sys_back
), anexei-a ao ubi, montei o mtdblock resultante e tudo funcionou como deveria, então presumo que meu volume ubi e o sistema de arquivos squashfs estejam corretos.
# ubiattach -m 18
# mount /dev/mtdblock23 /mnt/
# mount
/dev/mtdblock23 on /mnt type squashfs (ro,relatime)
Então, eu queria experimentar a configuração final. Eu mostrei a imagem da ubi para o mtd19 ( system
) e modifiquei meus parâmetros do kernel para conter isso:
ubi.mtd=system root=mtd:ubi_vol_rom rootfstype=squashfs
No entanto, a montagem do sistema de arquivos raiz falhou:
[ 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..
Então, no log, posso dizer que o ubi anexado ao mtd19 conforme o esperado, redimensionou a segunda partição ( ubi_vol_overlay
), criou duas partições mtd dos volumes ubi (mtd20
e mtd21
) e criou dois dispositivos de bloco além disso ( mtdblock20
e mtdblock21
), ótimo.
No entanto, a montagem do sistema de arquivos squashfs ( mtdblock20
) falhou. O log diz que tentou montar com ubifs mesmo que eu tenha dito explicitamente para usar o squashfs via o argumento rootfstype
.
Primeiro, achei que talvez o nome do dispositivo não estivesse sendo resolvido corretamente no parâmetro root=
, então tentei usar /dev/mtdblock20
, mas o resultado foi o mesmo.
Como posso forçar o kernel a montá-lo com squashfs em vez de ubifs?