我正在为 RPi 构建一个定制的内核。问题是 RPi 引导加载程序需要一个 vfat /boot 分区,而我打算最小化内核大小,因此需要从内核中删除 vfat 支持。
我读过 Embedded Linux Primer 和 Linux Kernel Development 书籍。据我了解,引导加载程序似乎使用 /boot 分区来查找内核和 initramfs 以及其他一些重要文件
我尝试从内核中删除 vfat 支持,同时将 /boot 格式化为 vfat。内核启动得很好。然而,systemd 卡在某个地方,说它无法挂载 /boot,这完全没问题,因为内核不支持 vfat。Systemd 然后给了我一个救援外壳。
我想知道,既然 RPi 引导加载程序已经支持 vfat,并且能够毫无问题地加载内核,有什么办法可以让 systemd 根本不挂载 /boot 吗?根据我的理解,由于这个阶段已经加载了内核,内核不需要访问 /boot 分区。
任何帮助将不胜感激。
systemd 将尝试挂载您在 中列出的文件系统
/etc/fstab
,因此如果您从中删除/boot
,/etc/fstab
则不应尝试挂载它。(我刚刚在 Fedora 系统上进行了测试,将其删除
/etc/fstab
并确认它没有安装。)systemd 确实有一些代码可以专门处理 EFI 分区,所以也许这就是您在 RPi 上拥有的东西,这就是触发挂载的原因......但这通常是使用自动挂载单元实现的,换句话说,它会尝试仅当有人查看内部时才安装它
/boot
。挂载逻辑
/etc/fstab
由systemd-fstab-generator实现,挂载 EFI 分区的逻辑由systemd-gpt-auto-generator实现。另一个有用的命令是
systemctl status /boot
(当您将它与支持 vfat 的内核一起安装时),它可以为您提供更多关于它来自何处的提示。