Linux内核驱动之Uboot(一)环境变量.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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)

dmz158 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档