- 1、本文档共7页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux内核驱动之Uboot(一)环境变量.doc
一 概述
Uboot环境变量根据配置文件存在两种定义方式:
外部环境变量和内部环境变量
外部环境变量指的是将环境变量定义在外部介质上面比如nand flash,nor flash,mmc等等,具体定义在什么外部介质需要根据配置文件的宏CONFIG_ENV_IS_IN_XX来定义比如:
#define CONFIG_ENV_IS_IN_MMC 1 :环境变量在MMC卡上面
#define CONFIG_ENV_IS_IN_NAND 1 :环境变量在nandflash上面
#define CONFIG_ENV_IS_IN_FLASH 1:环境变量在nor flash上面
#undef CONFIG_ENV_IS_NO_WHERE :废除内部环境变量的定义
内部环境变量指的是定义在uboot镜像里边的环境变量,由于不使用外部环境变量必须在配置文件中间定义宏
#define CONFIG_ENV_IS_NO_WHERE
二 环境变量的类型和用途
Uboot环境变量大概包括四种类型的变量
(1) 网络方面的环境变量 比如 serverip ipaddr netmask gatewayip
(2) bootcmd
(3) bootargs
(4) 杂项类型的 比如bootdelay ,baudrate,stdin,stdout
1 网络类型的环境变量
此方面的环境变量具体包括如下几种
serverip 服务器端的ip地址
ipaddr 板卡自己的ip地址
netmask 网络掩码
gatewayip 网关
ethaddr 以太网的mac地址
网络类型的环境变量主要是为tftp下载文件,挂载nfs根文件系统等网络行为做准备的
下面的指令将网络参数都设置好
setenv gatewayip ;setenv netmask ;setenv ipaddr ;setenv serverip ;saveenv
2 bootcmd
bootcmd是uboot启动完之后自动执行的命令(延时3秒后执行),bootcmd最重要的任务是加载内核到DDR上去,当然内核可能来自不同的介质包括nand ,mmc,网络等等,所以也存在不同类型的bootcmd命令下面介绍几种常用的.
nand 中加载内核
setenv bootcmd nboot 0nand0 0x580000;bootm 0saveenv;
mmc卡加载内核
setenv bootcmd mmc rescan 0;fatload mmc 0 0uImage;bootm 0saveenv;
tftp网络加载内核
setenv bootcmd tftpboot 008:uImage;bootm0saveenv;
上面的都是较为简单的bootcmd命令都是从相应的的介质中间读取内核到DDR上,然后bootm(bootm就是cpu跳转到这个地址执行代码),对于上述bootcmd命令必须有bootargs环境变量的配合,这样内核起来之后能够正确挂载文件系统同时获得来自uboot传给内核的参数
较为复杂的如下
setenv bootcmd mmc rescan 0;fatload mmc 0 0boot.scr;source 0saveenv
或者是如下
setenv bootcmd tftpboot 01:boot.scr;source 0saveenv
上述bootcmd命令使用的是脚本方式,也就是说从外部介质中间读入boot.scr的uboot脚本,然后uboot解析该脚本.由于是执行的脚本,其中可以嵌入较多的命令,可以进行较多的操作包括加载内核,设置bootargs环境变量对于使用脚本的bootcmd,我们去设置bootargs可能会不起作用,因为uboot脚本中可能也存在设置bootargs的命令,这样就会替换我们自己设置的bootargs
假如不想要使用boot.scr也可以使用上面的bootcmd来代替。
总的来说bootcmd是告诉uboot该从哪里加载内核并从哪里启动,每一个bootcmd都是一个可以执行的命令比如
mmc rescan 0;fatload mmc 0 0uImage;bootm 0可以使用上述方法直接启动内核
再比如mmc rescan 0;fatload mmc 0 0boot.scr;source 0可以使用上述方法做系统还原
文档评论(0)