目录
项目场景:
问题描述
原因分析:
解决方案:
?
项目场景:
arm开发板的linux根文件系统由烧录而得,从板子的mmc中读取根文件系统,但是如果在开发调试过程中,这个文件系统有修改,怎样将其保存下来,方便烧录到其他批量生产的板子上呢。将板载根文件系统导出,生成ext4格式的文件,这自然是个方法!但是此法繁杂,不实用。正点原子的开发板是这样做的,用nfs挂载虚拟机ubuntu中的根文件系统。
问题描述
我在虚拟机ubuntun搭建了nfs服务器(见博客Ubuntu 上搭建nfs服务器,方便开发板远程挂载根文件系统_汉尼拔勇闯天涯的博客-CSDN博客),在开发板的uboot内设置了bootargs(setenv bootargs 'console=ttyS0,115200 root=/dev/nfs nfsroot=192.168.2.128:/home/wang/nfs-801/rootfs,proto=tcp rootwait rw ip=192.168.2.100:192.168.2.128:192.168.2.1:255.255.255.0::eth1:off' ),但是启动根文件系统时报错:
VFS: Unable to mount root fs via NFS, trying floppy.
VFS: Cannot open root device "nfs" or unknown-block(2,0): error -6
Please append a correct "root=" boot option; here are the available partitions:
原因分析:
开发板加载完内核之后,再通过内核的nfs服务去挂载ubuntu虚拟机中的根文件系统。
若要实现上述功能,除了内核和虚拟机都支持nfs之外,还要保证两者的nfs版本一致。
我的内核版本是4.14.155,它默认使用的nfs版本是协议2。而我的ubuntu虚拟机是18.04,它的nfs支持的协议是v3:
注意:在nfs挂载的过程中 ,真正被挂载的根文件系统中是否有nfs服务,这一点不影响nfs挂载,不会导致挂载失败。
解决方案:
所以在开发板的uboot中,为内核指定和虚拟机相同的nfs协议版本,便能解决这个问题:
?bootargs参数由
setenv bootargs 'console=ttyS0,115200 root=/dev/nfs nfsroot=192.168.2.128:/home/wang/nfs-801/rootfs,proto=tcp rootwait rw ip=192.168.2.100:192.168.2.128:192.168.2.1:255.255.255.0::eth1:off'
改为
setenv bootargs 'console=ttyS0,115200 root=/dev/nfs nfsroot=192.168.2.128:/home/wang/nfs-801/rootfs,proto=tcp,nfsvers=3 rootwait rw ip=192.168.2.100:192.168.2.128:192.168.2.1:255.255.255.0::eth1:off'
其中增加,nfsvers=3
参考:【问题解决】Linux通过nfs挂载根文件系统报错:VFS: Unable to mount root fs via NFS, trying floppy_丨匿名用户丨的博客-CSDN博客_nfs 挂载失败
?
|