Buildroot 将完整的 rootfs 加载到 Ram 中

Buildroot to load full rootfs into Ram

我有一个基于 Arm 的嵌入式板。目前 RootFS 是 squashfs。我还处于开发阶段。 我当前的工作流程是:

  1. 在开发机器中进行更改。
  2. 创建新的 Root FS 映像。
  3. 将镜像烧录到板子的U盘中
  4. 重新启动并测试更改。

如您所见,上述工作流程效率不高。制作完整的文件系统镜像浪费了很多时间,而我的应用程序或文件系统中的一些脚本只需要微小的更改,刻录图像并重新启动。

我知道我可以创建初始 Ram 磁盘来保存 RootFS,我在 buildroot 中选择了那个选项,构建完成。

现在我有点困惑我应该在板上烧什么?这是否足以避免开发中的整个重建、刻录、重启周期。

我知道我需要在最后刻录图像以保留在板上,但我只想在确保我的更改生效后刻录一张最终图像。

这不允许您燃烧较小的零件。您仍然需要将完整图像复制到设备上的内存中。 有一个解决方法:在 U-Boot 中使用网络工具,即 tftpboot,在内存中下载图像,然后 运行 将其载入。

这是 PowerPC 板之一的示例:

nb_load=dhcp;run nb_load_dtb;run nb_load_vmlinuz;run nb_load_initrd
nb_load_initrd=tftpboot 0x1900000 /mybooklive/initrd
nb_load_vmlinuz=tftpboot 0x1000000 /mybooklive/vmlinuz
nb_load_dtb=tftpboot 0x1800000 /mybooklive/apollo3g.dtb
nb_boot=setenv bootargs ${nb_bootargs}; run nb_load; bootm 0x1000000 0x1900000 0x1800000
nb_bootargs=console=ttyS0,115200n8 ignore_loglevel

在 U-boot 命令行中启动 运行 run nb_boot

基本上你需要内核映像、初始 ram 磁盘和设备树 blob(以防你选择不在内核中编译它)。

这里是英特尔 Edison 开发板从 eMMC 启动的 U-Boot 选项的另一个示例:

setenv boot_edsboot 'zboot 0x100000 0 0x3000000 0x1000000'
setenv bootargs_edsboot 'console=tty1 console=ttyS2,115200n8 rootfstype=ramfs rw'
setenv bootcmd_edsboot 'setenv bootargs ${bootargs_edsboot}; run load_edsboot; run boot_edsboot'
setenv load_edsboot 'load mmc 0:9 0x100000 vmlinuz.efi; load mmc 0:9 0x3000000 initrd'

在 U-Boot 命令行中启动 运行 run bootcmd_edsboot

全文为 here

很明显,你需要根据你拥有的板获得正确的文件(DTB)和地址。