4-嵌入式系统的BootLoader技术1531.pptx
《4-嵌入式系统的BootLoader技术1531.pptx》由会员分享,可在线阅读,更多相关《4-嵌入式系统的BootLoader技术1531.pptx(44页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、嵌入式系统开发原理与实践陈文智 等 编著清华大学出版社清华大学出版社重点大学计算机专业系列教材重点大学计算机专业系列教材第四章 嵌入式系统的Boot Loader技术1.Boot Loader程序的基本概念程序的基本概念 2.Boot Loader的典型结构框架的典型结构框架 3.Boot Loader实验实验 实验一实验一 Boot Loader应用实验应用实验实验二实验二 U-BOOT的分析和移植的分析和移植1.Boot Loader程序的基本概念一个嵌入式一个嵌入式 Linux 系统从软件的角度看通常可以系统从软件的角度看通常可以分为四个层次:分为四个层次:1.引导加载程序。引导加载程序
2、。包括固化在固件包括固化在固件(firmware)中的中的 boot代码代码(可选可选),和,和 Boot Loader 两大部分。两大部分。2.Linux 内核。内核。特定于嵌入式板子的定制内核以及内核的启动参数。特定于嵌入式板子的定制内核以及内核的启动参数。3.文件系统。文件系统。包括根文件系统和建立于包括根文件系统和建立于 Flash 内存设备之上文件系统。内存设备之上文件系统。通常用通常用 ram disk 来作为来作为 root fs。4.用户应用程序。特定于用户的应用程序。用户应用程序。特定于用户的应用程序。有时在用户应用程序和内核层之间可能还会包括一个嵌入式图有时在用户应用程序和
3、内核层之间可能还会包括一个嵌入式图形用户界面。常用的嵌入式形用户界面。常用的嵌入式 GUI 有:有:MicroWindows 和和 MiniGUI 懂。懂。1.Boot Loader程序的基本概念Boot Loader就是在操作系统内核运行之前就是在操作系统内核运行之前运行的一段小程序运行的一段小程序 初始化硬件设备和建立内存空间的映射图初始化硬件设备和建立内存空间的映射图 将系统的软硬件环境带到一个合适的状态,以将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统内核准备好正确的环境便为最终调用操作系统内核准备好正确的环境 Boot Loader所支持的硬件环境所支持的硬件环境 Bo
4、ot Loader 是严重地依赖于硬件而实现的是严重地依赖于硬件而实现的每种不同的每种不同的CPU体系结构都有不同的体系结构都有不同的Boot Loader Boot Loader的安装地址的安装地址系统加电或复位后,所有的系统加电或复位后,所有的 CPU 通常都从某通常都从某个由个由 CPU 制造商预先安排的地址上取指令。制造商预先安排的地址上取指令。系统的系统的Boot Loader程序通常安排在地址程序通常安排在地址0 x00000000 处处 Boot Loader相关的设备和机制相关的设备和机制 主机和目标机之间一般通过串口建立连接主机和目标机之间一般通过串口建立连接 Boot Lo
5、ader 软件在执行时通常会通过串口来软件在执行时通常会通过串口来进行进行 I/O 超级终端超级终端Boot Loader的启动过程的启动过程 通常多阶段的通常多阶段的 Boot Loader 能提供更为复杂的能提供更为复杂的功能,以及更好的可移植性功能,以及更好的可移植性 分为 stage 1 和 stage 2 两部分 Boot Loader的操作模式的操作模式 启动加载模式启动加载模式 下载模式下载模式 Boot Loader与主机之间的通信设备及协议与主机之间的通信设备及协议 最常见的是串口,协议最常见的是串口,协议xmodem/ymodem/zmodem以太网,协议以太网,协议tft
6、p常用嵌入式常用嵌入式BootloaderU-boot:通用引导程序通用引导程序,ARM/XSCALE 平台平台 Blob:LART 等硬件平台的引导程序等硬件平台的引导程序,StrongARM RedBoot:基于基于 eCos 的引导程序的引导程序 2.Boot Loader的典型结构框架操作系统的角度看,操作系统的角度看,Boot Loader的总目标的总目标就是正确地调用内核来执行就是正确地调用内核来执行 大多数大多数Boot Loader都分为阶段都分为阶段1和阶段和阶段2两大部分两大部分 阶段阶段1实现依赖于实现依赖于CPU体系结构的代码体系结构的代码(汇编汇编)阶段阶段2实现一些
7、复杂的功能实现一些复杂的功能(C语言)语言)2.1 Boot Loader阶段1介绍Boot Loader 的阶段的阶段1通常包括以下步骤:通常包括以下步骤:1)硬件设备初始化。)硬件设备初始化。屏蔽所有的中断屏蔽所有的中断 设置设置CPU的速度和时钟频率的速度和时钟频率 RAM初始化初始化 初始化初始化LED 关闭关闭CPU内部指令数据内部指令数据Cache 2)为加载阶段为加载阶段2准备准备RAM空间空间 除了阶段除了阶段2可执行映象的大小外,还必须把堆可执行映象的大小外,还必须把堆栈空间也考虑进来栈空间也考虑进来 一般一般1M就够了就够了Blob是是0 xc0200000开始的开始的1M
8、B空间空间推荐:推荐:(RamEnd 1MB,RamEnd)标记标记Stage2_end=stage2_start+stage2_size2)为加载阶段)为加载阶段2准备准备RAM空间空间 必须确保所安排的地址范围的的确确是可读写的必须确保所安排的地址范围的的确确是可读写的RAM空间空间1.先保存先保存memory page一开始两个字的内容一开始两个字的内容2.向这两个字中写入任意的数字向这两个字中写入任意的数字3.立即将这两个字读回,若不是,则说明不是一段有效立即将这两个字读回,若不是,则说明不是一段有效的的RAM空间空间4.再向这两个字写入任意数字再向这两个字写入任意数字5.立即将这两个
9、字读回。若不是,则说明不是有效的立即将这两个字读回。若不是,则说明不是有效的RAM空间空间6.恢复这两个字的原始内容,测试完毕。恢复这两个字的原始内容,测试完毕。3)拷贝阶段)拷贝阶段2到到RAM中中 复制时要确定两点:复制时要确定两点:阶段阶段2的可执行映像在固态存储设备的存放其的可执行映像在固态存储设备的存放其实地址和终止地址实地址和终止地址RAM空间的起始地址空间的起始地址4)设置堆栈指针)设置堆栈指针sp 设置堆栈指针是为了执行设置堆栈指针是为了执行C语言代码做好准备语言代码做好准备通常可以设置为通常可以设置为sp=stage2_end 4此时,此时,Boot Loader 的的 阶段
10、阶段2 可执行映象刚可执行映象刚被拷贝到被拷贝到 RAM 空间时的系统内存布局,如下空间时的系统内存布局,如下图:图:5)跳转到阶段)跳转到阶段2的的C入口点入口点 修改修改PC寄存器为合适地址来实现寄存器为合适地址来实现2.2 Boot Loader阶段2介绍trampoline(弹簧床)的概念进入main()函数 用汇编语言写一段trampoline 小程序在 trampoline 汇编小程序中用 CPU 跳转指令跳入 main()函数中去执行;而当 main()函数返回时,CPU 执行路径显然再次回到 trampoline 程序 .text.globl _trampoline_tramp
11、oline:blmain/*if main ever returns we just call it again*/b _trampoline2.2 Boot Loader阶段2介绍1)初始化本阶段要使用到的硬件设备)初始化本阶段要使用到的硬件设备初始化至少一个串口,以便和终端用户进行初始化至少一个串口,以便和终端用户进行I/O输出信息输出信息 初始化计时器等初始化计时器等2)检测系统的内存映射)检测系统的内存映射 所谓内存映射就是指在整个所谓内存映射就是指在整个4GB物理地址空间物理地址空间中有哪些地址范围被分配用来寻址系统的中有哪些地址范围被分配用来寻址系统的RAM单元单元例如,例如,SA
12、1100CPU中,从中,从0 xC0000000开始开始的的512M但是,具体嵌入式系统并不实现全部预留地址,但是,具体嵌入式系统并不实现全部预留地址,可能仅用可能仅用64M因此,必须检测整个系统的内存映射情况因此,必须检测整个系统的内存映射情况2)检测系统的内存映射)检测系统的内存映射 可以用如下数据结构来描述可以用如下数据结构来描述RAM地址空间中的地址空间中的一段连续的地址范围:一段连续的地址范围:typedef struct memory_area_struct typedef struct memory_area_struct u32 start;/*u32 start;/*内存空内
13、存空间间的基址的基址*/*/u32 size;/*u32 size;/*内存空内存空间间的大小的大小*/*/int used;/*1int used;/*1已已实现实现0 0未未实现实现*/*/memory_area_t;memory_area_t;2)检测系统的内存映射)检测系统的内存映射 整个整个CPU预留的预留的RAM地址可用数组表示地址可用数组表示 memory_area_t memory_mapNUM_MEM_AREAS=memory_area_t memory_mapNUM_MEM_AREAS=0 (NUM_MEM_AREAS-1)=0 (NUM_MEM_AREAS-1)=.sta
14、rt=0,.start=0,.size=0;.size=0;.used=0 .used=0 ,;2)检测系统的内存映射)检测系统的内存映射 内存映射的检测内存映射的检测 memory_area_t memory_mapNUM_MEM_AREAS=memory_area_t memory_mapNUM_MEM_AREAS=0 (NUM_MEM_AREAS-1)=0 (NUM_MEM_AREAS-1)=.start=0,.start=0,.size=0;.size=0;.used=0 .used=0 ,;3)加载内核映像和根文件系统映像)加载内核映像和根文件系统映像 规划内存占用的布局规划内存占用
15、的布局 内核映像所占用的内存范围内核映像所占用的内存范围 一般是一般是MEM_START+0X8000到约到约1MB的空间的空间根文件系统所占用的内存范围根文件系统所占用的内存范围 一般是一般是MEM_START0 x100000开始的地方开始的地方3)加载内核映像和根文件系统映像)加载内核映像和根文件系统映像 从从Flash上拷贝上拷贝 由于像由于像ARM这样的嵌入式这样的嵌入式CPU通常都是在统一内存地址空间中寻通常都是在统一内存地址空间中寻址址FLASH等固态存储设备,因此从闪存上读取数据与从等固态存储设备,因此从闪存上读取数据与从RAM内存内存单元中读取数据并没有什么不同单元中读取数据
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 嵌入式 系统 BootLoader 技术 1531
限制150内