Bootloader: 简单地说,Bootloader 就是在操作系统内核运行之前运行的一段小程序。通过这段小程序,我们可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统内核做好准备。 所以Bootloader执行时要加载Linux内核,内核挂载根文件系统rootfs。一般在嵌入式Linux系统中,Flash设备中需要包含以上几部分,如下图: 常见的Bootloader: u-boot,blob Bootloader启动: 第一阶段(iRAM,8KB): 1. 关中断(FIQ和IRQ),关D-Cache(I-Cache可以打开),设置SVC模式,关MMU(内存管理单元),关Watchdog 2. 配置串口 3. 配置系统时钟 4. 初始化SDRAM(设置栈指针寄存器sp),以上都用汇编语言实现 5. C语言实现初始化NAND(eMMC,UFS) 6. 将bootloader拷贝到内存,并跳到SDRAM继续执行。 第二阶段(SDRAM): 7. 初始化网卡 8. 将内核(zImage/uImage)和设备树(Device Tree Blob)拷贝到SDRAM,准备启动参数(bootargs),跳到内核地址运行。 u-boot常用命令: U-Boot,全称 Universal Boot Loader,是遵循GPL条款的开放源码项目。 1.帮助命令help。 运行help 命令可以看到U-Boot 中所有命令的作用,如果要查看某个命令的使用方法, 运行“help 命令名”,比如“help bootm”。 可以使用“?”来代替“help”,比如直接输入“?”、“? bootm”。 ------------------------------------------------------------------------------------------------------------ 2.下载命令。 U-Boot 支持串口下载、网络下载,相关命令有:loadb、loads、loadx、loady 和tftpboot。 前几个串口下载命令使用方法相似,以loadx 命令为例,它的用法为“loadx [ off ][ baud ]”。“[]”表示里面的参数可以省略,off 表示文件下载后存放的内存地址,baud 表示使用的波特率。如果baud 参数省略,则使用当前的波特率;如果off 参数省略,存放的地址为配置文件中定义的宏CFG_LOAD_ADDR。 tftpboot 命令使用TFTP 协议从服务器下载文件,服务器的IP 地址为环境变量serverip。 用法为“tftpboot [loadAddress] [bootfilename]”,loadAddress 表示文件下载后存放的内存地址,bootfilename 表示要下载的文件的名称。如果loadAddress 省略,存放的地址为配置文件中定义的宏CFG_LOAD_ADDR;如果bootfilename 省略,则使用开发板的IP 地址构造一个文件名,比如开发板IP 为192.168.1.17,则默认的文件名为C0A80711.img。 nfs 命令使用NFS 协议下载文件,用法为“nfs [loadAddress] [host ip addr:bootfilename]”。 “loadAddress、bootfilename”的意义与tftpboot 命令一样,“host ip addr”表示服务器的IP 地址,默认为环境变量serverip。下载文件成功后,U-Boot 会自动创建或更新环境变量filesize,它表示下载的文件的长度,可以在后续命令中使用“$(filesize)”来引用它。 ----------------------------------------------------------------------------------------------------------- 3.内存操作命令。 常用的命令有:查看内存命令md、修改内存命令md、填充内存命令mw、复制命令cp。这些命令都可以带上后缀“.b”、“.w”或“.l”,表示以字节、字(2 个字节)、双字(4 个字节)为单位进行操作。比如“cp.l 30000000 31000000 2”将从开始地址0x30000000 处,复制2 个双字到开始地址为0x31000000 的地方。 md 命令用法为“md[.b, .w, .l] address [count]”,表示以字节、字或双字(默认为双字)为单位,显示从地址address 开始的内存数据,显示的数据个数为count。 mm 命令用法为“mm[.b, .w, .l] address”,表示以字节、字或双字(默认为双字)为单位,从地址address 开始修改内存数据。执行mm 命令后,输入新数据后回车,地址会自动增加,按“Ctrl+C”键退出。 mw 命令用法为“mw[.b, .w, .l] address value [count]”,表示以字节、字或双字(默认为双字)为单位,往开始地址为address 的内存中填充count 个数据,数据值为value。 cp 命令用法为“cp[.b, .w, .l] source target count”,表示以字节、字或双字(默认为双字) 为单位,从源地址source 的内存复制count 个数据到目的地址的内存。 ----------------------------------------------------------------------------------------------------------- 4. 启动命令。 不带参数的“boot”、“bootm”命令都是执行环境变量bootcmd 所指定的命令。 “bootm [addr [arg…]]”命令启动存放在地址addr 处的U-Boot 格式的映象文件(使用U-Boot 目录tools 下的mkimage 工具制作得到),[arg…]表示参数。如果addr 参数省略,映象文件所在地址为配置文件中定义的宏CFG_LOAD_ADDR。 “go addr [arg…]”与bootm 命令类似,启动存放在地址addr 处的二进制文件,[arg...]表示参数。 “nboot [[[loadAddr] dev] offset]”命令将NAND Flash 设备dev 上偏移地址off 处的映象文件复制到内存loadAddr 处,然后,如果环境变量autostart 的值为“yes”,就启动这个映象。如果loadAddr 参数省略,存放地址为配置文件中定义的宏CFG_LOAD_ADDR;如果dev 参数省略,则它的取值为环境变量bootdevice 的值;如果offset 参数省略,则默认为0 ----------------------------------------------------------------------------------------------------------- 5. 环境变量命令。 “printenv”命令打印全部环境变量,“printenv name1 name2?”打印名字为name1、name2、?的环境变量。 “setenv name value”设置名字为name 的环境变量的值为value。 “setenv name”删除名字为name 的环境变量。 上面的设置、删除操作只是在内存中进行,“saveenv”将更改后的所有环境变量写入Flash中。 ----------------------------------------------------------------------------------------------------------- 6. 从SD卡烧写 sdfuse,将FAT分区SD卡中镜像文件烧写到启动设备 sdfuse flashall,烧写全部分区,包括bootloader、kernel、ramdisk、Recovery、system、userdata、cache和fat.
共2条
1/1 1 跳转至页
u-boot介绍
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |