EASYARM-IMX283 nfs启动内核和根文件系统
EASYARM-IMX283(以下简称IMX283)默认采用从nand flash启动,但是在开发过程中因为要频繁的替换内核,我们更倾向于从nfs启动。
先看看IMX283中uboot中默认采用的启动选项,内容如下:
bootcmd=run nand_boot
bootdelay=
baudrate=
ipaddr=192.168.12.62
serverip=192.168.12.61
netmask=255.255.255.0
bootfile="uImage"
loadaddr=0x42000000
kernel=uImage
kernelsize=0x300000
rootfs=rootfs.ubifs
kerneladdr=0x00200000
nfsroot=/home/notroot/nfs/rootfs
bootargs_nfs=setenv bootargs ${bootargs} root=/dev/nfs ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp fec_mac=${ethaddr}
bootcmd_net=run bootargs_nfs; dhcp; bootm
bootcmd_mmc=run bootargs_mmc; mmc read ${loadaddr} ; bootm
bootargs_nand=gpmi=g console=ttyAM0,115200n8 console=tty0 ubi.mtd= root=ubi0:rootfs rootfstype=ubifs ip=192.168.12.180:192.168.12.48:192.68.12.1:255.255.255.0::eht0
bootargs_mmc=gpmi=g console=ttyAM0,115200n8 console=tty0 root=/dev/mmcblk0p3 rw ip=192.168.12.180:192.168.12.48:192.68.12.1:255.255.255.0::eh
bootargs=gpmi=g console=ttyAM0,115200n8 console=tty0 ubi.mtd= root=ubi0:rootfs rootfstype=ubifs ip=192.168.12.180:192.168.12.48:192.68.12.1:255.255.255.0::eht0: fec
kernel=uImage
upuboot=tftp $(loadaddr) $(serverip):imx28_ivt_uboot.sb;nand erase 0x0 0x100000; nand write $(loadaddr) 0x0 0x100000
upkernel=tftp $(loadaddr) $(serverip):$(kernel);nand erase $(kerneladdr) $(kernelsize);nand write $(loadaddr) $(kerneladdr) $(kernelsize);
setenv kernelsize $(filesize); saveenv
uprootfs=mtdparts default;nand erase rootfs;ubi part rootfs;ubi create rootfs;tftp $(loadaddr) $(rootfs);ubi write $(loadaddr) rootfs $(filesize)
tftp_boot=tftp $(loadaddr) $(serverip):uImage; bootm;
nand_boot=nand read.jffs2 $(loadaddr) $(kerneladdr) $(kernelsize);bootm $(loadaddr)
setnandboot=setenv bootcmd 'run nand_boot';saveenv
settftpboot=setenv bootcmd 'run tftp_boot';saveenv
upsystem=run upkernel;run uprootfs;reset
ethaddr=:::b3:c4:a8
stdin=serial
stdout=serial
stderr=serial
ethact=FEC0
其中bootcmd中内容为"run nand_boot",而nand_boot内容是“nand read.jffs2 $(loadaddr) $(kerneladdr) $(kernelsize);bootm $(loadaddr)”,
所以bootcmd实际上是nand read.jffs2 0x42000000 0x00200000 0x300000;bootm 0x42000000表示从0x200000开始3M大小的内容,拷贝到sram中0x42000000,然后从0x42000000启动内核。
bootargs中内容为“gpmi=g console=ttyAM0,115200n8 console=tty0 ubi.mtd= root=ubi0:rootfs rootfstype=ubifs ip=192.168.12.180:192.168.12.48:192.68.12.1:255.255.255.0::eht0: fec”
表示从ubi分区中启动rootfs,并将ip地址设置为192.168.12.180,nfs服务器ip地址为192.168.12.48,网关ip为192.168.12.1,广播地址为255.255.255.0
下面对uboot参数进行配置。
将uImage以及rootfs都移动到nfs文件夹下(我的nfs主目录是/home/host/nfs/imx283)
然后在/etc/exports中添加一行(其中nfs文件夹路径和ip地址需要根据自己进行修改):
/home/host/nfs/imx283 192.168.211.0/255.255.255.0(rw,no_root_squash)
然后重启nfs服务器。
/tec/init.d/nfs-kernel-server restart
首先配置ip地址:
MX28 U-Boot > setenv ipaddr 192.168.211.212
MX28 U-Boot > setenv serverip 192.168.211.2
然后在uboot下执行下面的命令测试nfs是否可用:
nfs 0x42000000 192.168.211.2:/home/host/nfs/imx283/uImage
但是u-boot提示了一个错误:
Using FEC0 device
File transfer via NFS from server 192.168.211.2; our IP address is 192.168.211.212
Filename '/home/host/nfs/imx283/uImage'.
Load address: 0x42000000
Loading: #################################################################
#################################################################
#################################################################
#################################################################
#################################################################
#################################################################
#################################################################
########################################*** ERROR: Cannot umount
从网络上找到的一个解决方案是在/etc/hosts文件中添加一行(开发板ip和nfs文件夹路径):
192.168.211.212 /home/host/nfs/imx283
然后再执行上面的命令(nfs 0x42000000 192.168.211.2:/home/host/nfs/imx283/uImage):
MX28 U-Boot > nfs 0x42000000 192.168.211.2:/home/host/nfs/imx283/uImage
Using FEC0 device
File transfer via NFS from server 192.168.211.2; our IP address is 192.168.211.212
Filename '/home/host/nfs/imx283/uImage'.
Load address: 0x42000000
Loading: #################################################################
#################################################################
#################################################################
#################################################################
#################################################################
#################################################################
#################################################################
########################################*** ERROR: Cannot umount
可以成功下载uImage.
配置nfs路径:
MX28 U-Boot > set nfsroot /home/host/nfs/imx283
设置bootcmd并保存:
setenv bootcmd nfs $(loadaddr) $(serverip):$(nfsroot)/uImage\;bootm $(loadaddr)
saveenv
在配置bootargs 从nfs启动跟文件系统:
MX28 U-Boot > set bootargs noinitrd root=/dev/nfs rw nfsroot=$(serverip):$(nfsroot)/rootfs ip=$(ipaddr) console=ttyAM0 init=/sbin/init
MX28 U-Boot > saveenv
按“RST”键重启开发板即可进入系统。
需要注意的是,IMX283的字符串不能自动识别双引号,如果使用setenv bootcmd “nfs $(loadaddr) $(serverip):$(nfsroot)/uImage\;bootm $(loadaddr)“,
那么在引导内核时会提示nfs命令不能识别的错误。
EASYARM-IMX283 nfs启动内核和根文件系统的更多相关文章
- uboot下 Nand flash 启动 内核与根文件系统
u-boot版本: u-boot-2010.03_tekkamanninja修改的u-boot 1.将uboot通过j-link烧写到norflash,启动后 saveenv 将参数保存到 nandf ...
- 嵌入式linux加载引导内核和根文件系统的方法
总体来说,嵌入式Linux内核和根文件的引导与PC机差不多.嵌入式linux内核和根文件系统可以存放在各种可能的存储设备中,一般情况下我 们将内核和根文件系统直接烧入到Flash中(包括NOR和NAN ...
- Linux内核与根文件系统的关系1
Linux内核与根文件系统的关系开篇题外话:对于Linux初学者来说,这是一个很纠结的问题,但这也是一个很关键的问题!一语破天机: “尽管内核是 Linux 的核心,但文件却是用户与操作系统交互所采用 ...
- Linux内核与根文件系统的关系
开篇题外话:对于Linux初学者来说,这是一个很纠结的问题,但这也是一个很关键的问题! 一语破天机: “尽管内核是 Linux 的核心,但文件却是用户与操作系统交互所采用的主要工具.这 ...
- Linux内核和根文件系统引导加载程序
续博文<u-boot之u-boot-2009.11启动过程分析> Linux内核启动及文件系统载入过程 当u-boot開始运行bootcmd命令.就进入Linux内核启动阶段,与u-boo ...
- 使用NFS启动Tiny4412开发板根文件系统
1.Ubuntu14.04上搭建NFS服务 1.1.安装NFS服务 $ sudo apt-get install nfs-kernel-server //安装NFS服务 1.2 创建Tiny ...
- debian下为stm32f429i-discovery编译uboot、linux内核和根文件系统
交叉编译器:arm-uclinuxeabi-2010q1 交叉编译器下载下来后解压,然后将其中bin文件夹路径加入到PATH变量中. 根据<debian下烧写stm32f429I discove ...
- linux内核挂载根文件系统时报错”VFS: Cannot open root device "ram0" or unknown-block(0,0): error -6“如何处理?
1. 通过error -6得到: #define ENXIO 6 /* No such device or address */ 2. 解决办法 使能CONFIG_BL ...
- 使用qemu模拟调试内核和debian根文件系统
开发环境:Ubuntu 14.04.3 LTS 64bit sudo debootstrap jessie /mnt/jessie http://mirrors.163.com/debian 在 ...
随机推荐
- js 快速排序
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js 选项卡封装
function tab(input,div){ for(var i = 0; i < input.length; i++){ input[i].index = i; input[i].oncl ...
- C 作用域规则
C 作用域规则 任何一种编程中,作用域是程序中定义的变量所存在的区域,超过该区域变量就不能被访问.C 语言中有三个地方可以声明变量: 在函数或块内部的局部变量 在所有函数外部的全局变量 在形式参数的函 ...
- Bootstrap 模态框、轮播 结合使用
Bootstrap 模态框和轮播分开使用的教程网上非常多.可是两者结合使用的样例和资料非常少. 两者结合使用时,開始我遇到了不少bug,如今分享给大家. 我的这个样例是把图片轮播嵌入到模态框里. 最后 ...
- fiddler不能监听 localhost和 127.0.0.1的问题 .
localhost/127.0.0.1的请求不会通过任何代理发送,fiddler也就无法截获. 解决方案 用 http://localhost. (locahost紧跟一个点号) 用 http://1 ...
- HTTP头解读
Http协议定义了很多与服务器交互的方法,最基本的有4种,分别是GET.POST.PUT.DELETE.一个URL地址用于描述一个网络上的资源, 而HTTP中的GET.POST.PUT. DELETE ...
- vs2010+qt4编译出现error LNK2001: 无法解析的外部符号 "public: virtual struct QMetaObject等错误
1.当vs2010编译qt时会出现以下错误: 1>------ 已启动全部重新生成: 项目: MyDialog, 配置: Debug Win32 ------ 1>生 ...
- 写一段代码,判断一个包括'{','[','(',')',']','}'的表达式是否合法(注意看样例的合法规则。) 给定一个表达式A,请返回一个bool值,代表它是否合法。
这道题比较奇怪,它的匹配规则并不是我们平时想想的那种匹配规则,例如:平时的匹配规则是().{}.[]才能匹配,本题中(和} .].)都能匹配.所以做题时要好好审题.另外,本题中给的测试用例是错误的. ...
- 华为p20:拍美景,听讲解,旅行更智能
华为P20轰轰烈烈地上市了,本来对手机并不感冒的我,看到身边的好友换了P20,不禁感慨:这个月的活又要白干了,全部都要上交给华为,因为这款手机完全戳中了旅游爱好者的痛点. 痛点一:丢弃笨重的单反,手机 ...
- 把对象写入Postgresql中
工作中,遇到把大对象写入Postgresql数据库中 package com.geni_sage.gdme.cws.dic; import java.io.BufferedInputStream; i ...