转自:http://bbs.elecfans.com/jishu_455028_1_1.html


如6410的bootcmd和bootargs默认存在于uboot1.1.6/include/configs/smdk6410.h

the older version's of u-boot used boot.scr to set boot parameter

setenv bootargs 'console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 rootwait omapfb.mode=dvi:1280x1024MR-32 at 60 vram=12M' setenv bootcmd 'mmc init; fatload mmc 0 80000000 uImage; bootm 80000000'

boot

Newer version's of u-boot now look for a uEnv.txt file to set boot parameter

mpurate=
dvimode=800x600MR-@
vram=4MB
bootargs "console=ttyS2,115200n8 root=/dev/mmcblk0p2 rootwait ro
vram=${vram} omapfb.mode=dvi:${dvimode} omapfb.vram=:2M,:2M mem=208M@0x80000000"
boot

By default, the frame buffer is only allocated for /dev/fb0. Option vram should be specified in u-boot bootargs variable to allocate frame buffer for /dev/fb1. For example:   vram=8M omapfb.vram=4M,4M

---------------------------------------------------------------------------------------------------------------------------------------------

1.bootcmd和bootargs

通过串口连接BeagleBone Black,参见http://elinux.org/Beagleboard:Terminal_Shells
启动到U-Boot的时候,会看到

Hit any key to stop autoboot:

按下任意键则放弃自动引导,从而进入了U-Boot的命令行, 在这里你可以手动进行接下来系统的引导。

下面来了解U-Boot是如何引导系统的。


在U-Boot的官网手册中看到了2个关键的环境变量和1个命令。
bootcmd: This variable defines a command string that is automatically executed 
         when the initial countdown is not interrupted.
         This command is only executed when the variable bootdelay is also defined!
bootargs: The contents of this variable are passed to the Linux kernel as boot 
          arguments (aka "command line").

run    - run commands in an environment variable


bootcmd中的命令就是出现“Hit any key to stop autoboot”提示后,不按任意键,会自动运行的命令。
bootargs是传递给Linux内核的参数。
run是运行环境变量中的命令,bootcmd中包含run命令。

所以分析引导过程要从bootcmd开始。
在U-Boot的命令行中输入printenv可显示所有的环境变量,我已经把相关的粘贴到了下面。
为方便阅读我添加了换行。

bootcmd=
run findfdt;
run mmcboot;
setenv mmcdev ;
setenv bootpart :;
run mmcboot;
run nandboot;

下面就分别从bootcmd内容说起:

2.1.findfdt

首先是运行findfdt中的命令,目的是通过board_name来设置fdtfile,结果是fdtfile的值为am335x-boneblack.dtb

findfdt=
if test $board_name = A335BONE;
then
setenv fdtfile am335x-bone.dtb;
fi;
if test $board_name = A335BNLT;
then
setenv fdtfile am335x-boneblack.dtb;
fi;
if test $board_name = A33515BB;
then
setenv fdtfile am335x-evm.dtb;
fi;
if test $board_name = A335X_SK;
then
setenv fdtfile am335x-evmsk.dtb;
fi;
if test $fdtfile = undefined;
then
echo WARNING: Could not determine device tree to use;
fi;
board_name=A335BNLT

2.2.mmcboot

"mmc dev 0"是将设备切换到0,通常有2个设备一个是SD卡,一个是eMMC

mmcboot=
mmc dev ${mmcdev};
if mmc rescan;
then
echo SD/MMC found on device ${mmcdev};
if run loadbootenv;
then
echo Loaded environment from ${bootenv};
run importbootenv;
fi;
if test -n $uenvcmd;
then
echo Running uenvcmd ...;
run uenvcmd;
fi;
if run loadimage;
then
run mmcloados;
fi;
fi;
mmcdev=

2.2.1.loadbootenv

这应该是从设备0的第1个分区装载uEnv.txt到地址0x80200000。
当默认的环境变量不符合要求时,可以用uEnv.txt设置新的环境变量。没有它也可以,先不用管,后面说。

loadbootenv=load mmc ${mmcdev} ${loadaddr} ${bootenv}
loadaddr=0x80200000
bootenv=uEnv.txt

2.2.2.importbootenv

这是把uEnv.txt中的环境变量导入到U-Boot的环境变量中。“filesize”没有指定。

importbootenv=echo Importing environment from mmc ...; env import -t $loadaddr $filesize

由于我没有“uenvcmd”这个环境变量,所以那个条件语句中的内容没有执行。我记着Arch Linux好像用了那个,那个变量应该在uEnv.txt中。

2.2.3.loadimage

于是直接到了loadimage,这里和载入uEnv.txt是相似的,“0:2”的意思是设备0的第2个分区,而载入uEnv.txt时没有指定分区,就默认第1分区了。
loadimage目的是将Linux内核载入内存。

loadimage=load mmc ${bootpart} ${loadaddr} ${bootdir}/${bootfile}
bootpart=:
bootdir=/boot
bootfile=zImage

2.2.4.mmcloados

mmcloados=
run mmcargs;
if test ${boot_fdt} = yes || test ${boot_fdt} = try;
then
if run loadfdt;
then
bootz ${loadaddr} - ${fdtaddr};
else
if test ${boot_fdt} = try;
then
bootz;
else
echo WARN: Cannot load the DT;
fi;
fi;
else
bootz;
fi;

2.2.5.mmcargs

这个就是设置bootargs这一个环境变量而已,用于向内核传递参数。

mmcargs=setenv bootargs console=${console} ${optargs} root=${mmcroot} rootfstype=${mmcrootfstype}
console=ttyO0,115200n8
mmcroot=/dev/mmcblk0p2 ro
mmcrootfstype=ext4 rootwait

之前载入了Linux内核,这里载入了设备树文件。
最后通过bootz后接2个地址就启动了系统。

boot_fdt=try
loadfdt
=load mmc ${bootpart} ${fdtaddr} ${bootdir}/${fdtfile}
fdtaddr=0x80F80000

3.总结如下

这是默认环境变量的行为。而我们的系统可能与其不同。这就要修改环境变量。
我知道有2种方式,一种是在U-Boot的命令行中通过命令修改,另一种就是通过uEnv.txt了。

  • uboot命令方式
mmc dev ;
load mmc : 0x80200000 /boot/zImage
setenv bootargs concole=ttyO0,115200n8 root=mmcroot=/dev/mmcblk0p2 ro rootfstype=ext4 rootwait
load mmc : 0x80F80000 /boot/am335x-boneblack.dtb
bootz 0x80200000 - 0x80F80000
  • uEnv.txt方式

这里介绍uEnv.txt的方式。先列出我uEnv.txt的内容,不用详细看,看我下面的说明。

bootfile=uImage
loadfdt=load mmc ${bootpart} ${fdtaddr} ${bootdir}/dts/${fdtfile}
mmcloados=run mmcargs;
if test ${boot_fdt} = yes || test ${boot_fdt} =try;
then
if run loadfdt;
then
bootm ${loadaddr} - ${fdtaddr};
else if test ${boot_fdt} = try;
then
bootz;
else
echo WARN: Cannot load the DT;
fi;
fi;
else
bootz;
fi;
mmcroot=/dev/mmcblk0p2 rw
mmcargs=setenv bootargs console=${console} ${optargs} root=${mmcroot} rootfstype=${mmcrootfstype} init=/usr/lib/systemd/systemd

一共6行,最后一行空白。
bootfile: 修改了内核名字,
loadfdt: 中只是在目录中加了“dts/”,
mmcloados: 主要是把bootz改成bootm。
mmcroot: 把只读改成了读写。
mmcargs: 只是在后面指定了init为systemd,也有其他方法,如init为指向systemd的软链接。

这里是从设备0启动系统,怎样知道自己的系统位于哪个设备呢,也许有某种约定,比如如果有SD卡,那么SD卡是0。
我不知道的话,可以在U-Boot的命令行中通过命令判断。如,

U-Boot# mmc list
OMAP SD
/MMC: 0
OMAP SD/MMC: 1

列出mmc设备:

U-Boot# mmc dev
mmc0 is current device

显示当前是那个设备:

U-Boot# mmc part
Partition Map for MMC device -- Partition Type: DOS
Part Start Sector Num Sectors UUID Type
29942d7e- 0c Boot
29942d7e-

显示当前设备的分区信息:

U-Boot# ls mmc 0:1
mlo
u-boot.img
uenv.txt
file(s), dir(s)

列出设备0第1个分区“/”目录的文件,我没有指定,默认为“/”。

附录:printenv内容

OpenJTAG> printenv
bootcmd=nand read.jffs2 0x30007FC0 kernel; bootm 0x30007FC0
bootdelay=
baudrate=
ethaddr=::3e::0a:5b
netmask=255.255.255.0
mtdids=nand0=nandflash0
mtdparts=mtdparts=nandflash0:256k@(bootloader),128k(params),2m(kernel),-(root)
ipaddr=192.168.1.66 //开发板ip地址

bootargs
=root=/dev/nfs rw nfsroot=192.168.1.88:/home/book/Videos/rootfs/ ip=192.168.1.66 console=ttySAC0 mem=64M //uboot中nfs文件系统参数192.168.1.88ubuntu系统ip地址
serverip=192.168.1.100 //xp中的ip地址 stdin=serial
stdout=serial
stderr=serial
partition=nand0,
mtddevnum=
mtddevname=bootloader

[uboot]uboot如何引导系统的更多相关文章

  1. UEFI引导系统

    UEFI引导系统 1 2 3 4 5 6 7 分步阅读 现在的电脑大多数使用了UEFI引导系统(原来都是使用BIOS),从而加快启动速度,但同时也给用惯BIOS的用户带来很多困惑!为啥电脑不能识别制作 ...

  2. Nero8刻录引导系统光盘镜像图文教程

    刻录可引导的Windows系统光盘一直是电脑使用者较为需要的,今天,倡萌抽空写了这篇图文教程,希望对于菜鸟级的朋友有所帮助,大虾请飘过.本教程以最为强大的刻录软件Nero 8做为工具(其他版本的Ner ...

  3. linux引导系统

    一.linux引导系统 1.选择操作系统 /etc/grub.conf 设置grub引导装载程序口令,使用单用户模式时必须输入此密码 password --md5 md5后的密码字符串(可以通过gru ...

  4. grub覆盖mbr引导系统

    grub覆盖mbr引导系统 0.个人PC,WIN 7 + Kali,easybcd 不起作用,需要制作 kali 安装盘 PS:推荐使用 universal usb installer 制作. 方案一 ...

  5. Linux 服务器 U盘安装(避免U盘启动)以及拔除U盘后无法引导系统

    一.U盘制作 首先下载两个文件: ·         rhel-server-6.3-i386-boot.iso    启动镜像 ·         rhel-server-6.3-i386-dvd. ...

  6. 关于grub修复引导系统

    这周末遇到停电,机房的一台数据服务器启动不了,开机硬件自检以后,就停留在一个黑屏状态左上角有光标闪烁,却一直进入不了系统. 还好手里有centos6.5的系统盘,进入修复选项,具体进入修复请参照这里 ...

  7. [uboot]uboot中run的一些command在源码位置

    如在uEnv.txt中, loadfdt=fatload mmc ${mmcdev}: ${fdtaddr} ${fdtfile} fdtboot=run mmc_args; bootz ${load ...

  8. Maxdos 9.3不能引导系统进入Maxdos

    一.故障描述 最近安装一台新电脑安装的系统版本是windows7_professional_with_sp1_x64,安装完成后想用Maxdos对系统进行备份.出现错误:Warning: the hi ...

  9. Native Boot 从一个 VHD 引导系统的相关说明

    Native Boot 是 Windows 7 和 Windows Server 2008 R2 提供的一个新的功能,它允许从一个 VHD 文件引导一个操作系统,但是需要注意的是目前的 Windows ...

随机推荐

  1. (LeetCode 53)Maximum Subarray

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  2. UVA 270 Lining Up (几何 判断共线点)

     Lining Up  ``How am I ever going to solve this problem?" said the pilot. Indeed, the pilot was ...

  3. Oracle 计算表占用空间大小

    我们可以通过系统视图DBA_SEGMENTS.USER_SEGMETNS.DBA_TABLES来查看一个表所占空间的大小,如下所示: SELECT SEGMENT_NAME TABLE_NAME ,S ...

  4. 在 Linux 系统下使用 PhotoRec 工具来恢复已删除或丢失的文件

    PhotoRec – Recover Deleted or Lost Files in Linux 在 Linux 系统下使用 PhotoRec 工具来恢复已删除或丢失的文件 当你在系统中有意或无意地 ...

  5. CRNN中英文字符识别

    代码地址如下:http://www.demodashi.com/demo/13870.html 参考GitHub源码:https://github.com/YoungMiao/crnn 应demo大师 ...

  6. Linux下 iptables防火墙 放开相关port 拒绝相关port 及查看已放开port

    我用的是fedora 14 1. 查看iptables 防火墙已经开启的port:/etc/init.d/iptables status [root@hzswtb2-mpc ~]#/etc/rc.d/ ...

  7. oracle导出数据库dmp文件

    导出数据库为dmp文件,按照当前导出时间设置文件名称 @ECHO OFF ECHO 备份 SCOTT 用户的数据…… SET DBUserName=scott SET DBPassword= SET ...

  8. 使用overflow:hidden处理元素溢出和坍塌

    溢出 css溢出示意如图,子元素(背景为粉色)的长度或宽度超出父元素(背景为绿色). 通过为父元素赋 overflow:hidden 样式可将子元素超出父元素的部分隐藏起来. 也可为父元素赋 over ...

  9. Windows7下搭建Android开发环境

    以后工作中要用到android开发,所以想搭建好开发环境,笔记本装的是win7 准备文件: 1 下载Android SDK http://code.google.com/android/downloa ...

  10. 使用jquery的 uploadify,在谷歌浏览器上总会崩溃的解决方法

    最近做的项目使用了jquery的uploadify,但是在谷歌浏览器测试总是会出现崩溃.如: 因为是java项目. 解决的办法是: 给引入的js加上一个参数,时间戳就可以,防止缓存,使每一次都请求.( ...