当前位置:首页 > 芯闻号 > 充电吧
[导读]作者:华清远见讲师Bootloader:简单地说,Bootloader 就是在操作系统内核运行之前运行的一段小程序。通过这段小程序,我们可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境

作者:华清远见讲师


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.

sdfuse flash [ ] 烧写制定分区

sdfuse erase 擦除制定分区

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在这篇文章中,小编将为大家带来浏览器缓存的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: 浏览器 缓存 浏览器缓存

为增进大家对浏览器缓存的认识,本文将对浏览器缓存的清空方法以及清空浏览器缓存时需要注意的事项予以介绍。

关键字: 浏览器 指数 缓存

业内消息,近日谷歌正式移除了另一个对用户有用的功能网页缓存。搜索引擎之父Danny·Sullivan和谷歌搜索联络(Search Liaison)账号确认网页缓存功能被移除了,搜索页面缓存的 incache: 语法也将被...

关键字: 谷歌 缓存

固态硬盘的缓存主要分为DRAM Buffer 、SLC Cache、Host Memory Buffer。这三种缓存,有何区别?本文将带你深入了解三种缓存对工业级固态硬盘的重要性。

关键字: 威刚工控 缓存 固态硬盘

为增进大家对CPU的认识,本文将对CPU的缓存予以介绍。

关键字: CPU 指数 缓存

CPU中央处理器将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对它的相关情况以及信息有所认识和了解,详细内容如下。

关键字: CPU 中央处理器 缓存

在这几年,AMD和台积电合作,推出工艺更先进的Zen3\Zen4芯片,率先进入7nm、5nm;ARM先在服务器端抢了X86的份额,后在PC端也抢X86份额;苹果更“狠”,用M1芯片替换掉X86的芯片。

关键字: Intel 13 酷睿 缓存

在这篇文章中,小编将为大家带来CPU的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: CPU 缓存 负载

缓存(cache),原始意义是指访问速度比一般随机存取存储器(RAM)快的一种高速存储器,通常它不像系统主存那样使用DRAM技术,而使用昂贵但较快速的SRAM技术。缓存的设置是所有现代计算机系统发挥高性能的重要因素之一。

关键字: 缓存 RAM DRAM

关注星标公众号,不错过精彩内容来源|综合来自网络内容嵌入式软件工程师听说过u-boot和bootloader,但很多工程师依然不知道他们到底是啥。今天就来简单讲讲 u-boot 和 bootloader的内容以及区别。B...

关键字: u-boot
关闭
关闭