报错如下:
VFS: Unable to mount root fs via NFS, trying floppy.
VFS: Cannot open root device “nfs” or unknown-block(2,0): error -6
······
Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(2,0)
—[end Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(2,0)]
- 网上其他文章也有同样报错,但是他们的解决方法对我不适用。我重新对照正点原子视频教程里的环境变量,发现是设备树问题。故记录
解决方法
第一种
(后来补充:bootcmd应该是控制通过tftp写zImage和dtb,写入zImage和dtb成功应该就不是bootcmd的问题。)
确认bootcmd环境变量,设备树文件要是imx6ull-alientek-emmc.dtb
我的bootcmd配置如下
setenv bootcmd 'tftp 80800000 zImage; tftp 83000000 imx6ull-alientek-emmc.dtb; bootz 80800000 - 83000000'
第二种
可能是网络冲突引起
- 我的开发板通过网线连接电脑,电脑wifi上网,虚拟机桥接
- 开发板重启后,uboot里是ping不通ubuntu的,必须关闭一下wifi,就能ping通了,之后再开启wifi也能ping通。
- 这时又发现一个问题,虽然再次开启wifi后,uboot里仍然能ping通ubuntu,但是就会导致nfs挂载失败。应该是网络冲突导致的
- 解决办法就是关闭wifi知道 nfs挂载成功后再开启wifi
第三种
nfs版本问题,这种原因应该是发生于ubuntu18之后的系统
- 首先在/etc/default/nfs-kernel-server 文件中做以下修改
然后,修改bootargs,将../rootfs
修改为../rootfs,v3,tcp
问题解决