折腾rk3399的开发板的时候,突然发现overlayroot这个词汇。
我移植一下linux5.10的内核到firefly3399开发板,结果启动之后文件系统提示只读!!!
这就让我很莫名。后来看到mount文件系统的情况,感觉也是不可思议。
百度了一下overlayroot,觉得这个确实还是很不错的功能,尤其是对于嵌入式。
整个文件系统是只读,当开始使用的时候,他所有的数据都保存在另一个分区中/userdata目录下。
当文件系统出问题的时候,可以进行恢复出厂设置:
这样系统会格式化/userdata分区,恢复到系统最开始的样子。
recovery是firefly的一个执行程序,
但是网上的方法都是自己安装overlayroot的软件包实现,firefly并不是的。
firefly是通过ramdisk实现的,详情请分析randisk.img中的启动脚本,这个不做详细介绍。
chosen { //使用firefly的
bootargs = "earlycon=uart8250,mmio32,0xff1a0000 swiotlb=1 console=ttyFIQ0 ro root=PARTLABEL=rootfs rootfstype=ext4 rootwait overlayroot=device:dev=PARTLABEL=userdata,fstype=ext4,mkfs=1 coherent_pool=1m systemd.gpt_auto=0 cgroup_enable=memory swapaccount=1";
};
CMDLINE: mtdparts=rk29xxnand:0x00002000@0x00004000(uboot),0x00002000@0x00006000(trust),0x00002000@0x00008000(misc),0x00040000@0x0000a000(boot:bootable),0x00020000@0x0004a000(recovery),0x00010000@0x0006a000(backup),0xA00000@0x0007a000(rootfs),-@0xA80000(userdata:grow)
这个里面:
2.1 看到jc3399的文件系统大小是3g(实际img是3.9g,预留5G空间吧),即0xA00000(16进制表示,扇区总数) 5*1024*1024*1024/512 算出扇区数。
2.2 boot分区保留128M,能够适用于extboot的方式。(当然也是支持rkboot的格式)
2.3 boot之后的分区的起始位置注意一下,都有相应的调整,尤其是recovery和rootfs的起始位置!!
2.4 分区表中userdata 要有,这是用于存储数据的。
2.5 注意:extboot的方式需要把uboot更新到2.5.1c之后的版本,会更好一些。
File systems --->
<*> Overlay filesystem support
要选中这个!!!
rkboot的格式也需要增加!! 参考下面的语句吧:
./mkbootimg --kernel arch/arm64/boot/Image --ramdisk ramdisk.img --second resource.img -o boot.img