Bootloader 启动流程 和 概念 介绍
1.概念
简单地说,Bootloader 就是在操作系统内核运行之前运行的一段程序,它类似于 PC机中的 BIOS 程序。通过这段程序,可以完成硬件设备的初始化,并建立内存空间的映射图的功能,从而将系统的软硬件环境带到一个合适的状态,为最终调用系统内核做好准备。 通常,Bootloader 是严重地依赖于硬件实现的,特别是在嵌入式中。因此,在嵌入式世界里建立一个通用的 Bootloader 几乎是不可能的。但还是有一些通用的概念来指导用户特定的Bootloader 设计与实现。

(1)Bootloader 所支持的CPU和嵌入式开发板
每种不同的 CPU体系结构都有不同的Bootloader。有些 Bootloader 也支持多种体系结构的CPU,如后面要介绍的U-Boot就同时支持 ARM体系结构和 MIPS体系结构。除了依赖于CPU的体系结构外,Bootloader 实际上也依赖于具体的嵌入式板级设备的配置。
(2)Bootloader 的安装媒介
系统加电或复位后, 所有的CPU通常都从某个由 CPU制造商预先安排的地址上取指令。而基于CPU构建的嵌入式系统通常都有某种类型的固态存储设备(比如 ROM、EEPROM或FLASH 等) 被映射到这个预先安排的地址上。 因此在系统加电后, CPU将首先执行 Bootloader
程序。
(3)Bootloader 的启动过程分为单阶段和多阶段两种。通常多阶段的 Bootloader 能提供更为复杂的功能,以及更好的可移植性。
(4)Bootloader 的操作模式。大多数Bootloader 都包含两种不同的操作模式: “启动加载”模
式和“下载”模式,这种区别仅对于开发人员才有意义。 
启动加载模式:这种模式也称为“自主”模式。也就是 Bootloader 从目标机上的某个固态存储设备上将操作系统加载到 RAM 中运行,整个过程并没有用户的介入。这种模式是嵌入式产品发布时的通用模式。
下载模式:在这种模式下,目标机上的 Bootloader 将通过串口连接或网络连接等通信手段从主机(Host)下载文件,比如:下载内核映像和根文件系统映像等。从主机下载的文件通常首先被 Bootloader 保存到目标机的 RAM 中,然后再被 Bootloader 写到目标机上的FLASH 类固态存储设备中。Bootloader 的这种模系统是在更新时使用。工作于这种模式下的Bootloader 通常都会向它的终端用户提供一个简单的命令行接口。
(5)Bootloader 与主机之间进行文件传输所用的通信设备及协议,最常见的情况就是,目标机上的 Bootloader 通过串口与主机之间进行文件传输,传输协议通常是 xmodem/ ymodem/zmodem协议中的一种。但是,串口传输的速度是有限的,因此通过以太网连接并借助TFTP协议来下载文件是个更好的选择。
2.Bootloader 启动流程
Bootloader 的启动流程一般分为两个阶段:stage1和 stage2,下面分别对这两个阶段进行讲解:
(1)Bootloader 的stage1
在stage1中Bootloader 主要完成以下工作。  基本的硬件初始化,包括屏蔽所有的中断、设置 CPU的速度和时钟频率、RAM初始
化、初始化LED、关闭CPU内部指令和数据 cache灯。
为加载stage2准备RAM空间,通常为了获得更快的执行速度,通常把 stage2加载到RAM空间中来执行, 因此必须为加载Bootloader的stage2准备好一段可用的RAM空间范围。  
拷贝stage2到RAM中,在这里要确定两点:①stage2的可执行映像在固态存储设备的存放起始地址和终止地址;②RAM空间的起始地址。 
设置堆栈指针sp,这是为执行stage2的 C语言代码做好准备。
(2)Bootloader 的stage2
----在stage2中Bootloader 主要完成以下工作。 用汇编语言跳转到main入口函数 由于stage2的代码通常用C语言来实现,目的是实现更复杂的功能和取得更好的代码可读性和可移植性。但是与普通C语言应用程序不同的是,在编译和链接 Bootloader 这样的程序时,不能使用glibc库中的任何支持函数。 
---- 初始化本阶段要使用到的硬件设备,包括初始化串口、初始化计时器等。在初始化这些设备之前、可以输出一些打印信息。
-----检测系统的内存映射,所谓内存映射就是指在整个 4GB 物理地址空间中有指出哪些地址范围被分配用来寻址系统的RAM单元。
-----加载内核映像和根文件系统映像, 这里包括规划内存占用的布局和从 Flash上拷贝数据。
------设置内核的启动参数。

《Bootloader 启动流程和概念介绍》相关推荐

  1. ComeFuture英伽学院——2020年 全国大学生英语竞赛【C类初赛真题解析】(持续更新)

    视频:ComeFuture英伽学院--2019年 全国大学生英语竞赛[C类初赛真题解析]大小作文--详细解析 课件:[课件]2019年大学生英语竞赛C类初赛.pdf 视频:2020年全国大学生英语竞赛 ...

  2. ComeFuture英伽学院——2019年 全国大学生英语竞赛【C类初赛真题解析】大小作文——详细解析

    视频:ComeFuture英伽学院--2019年 全国大学生英语竞赛[C类初赛真题解析]大小作文--详细解析 课件:[课件]2019年大学生英语竞赛C类初赛.pdf 视频:2020年全国大学生英语竞赛 ...

  3. 信息学奥赛真题解析(玩具谜题)

    玩具谜题(2016年信息学奥赛提高组真题) 题目描述 小南有一套可爱的玩具小人, 它们各有不同的职业.有一天, 这些玩具小人把小南的眼镜藏了起来.小南发现玩具小人们围成了一个圈,它们有的面朝圈内,有的 ...

  4. 信息学奥赛之初赛 第1轮 讲解(01-08课)

    信息学奥赛之初赛讲解 01 计算机概述 系统基本结构 信息学奥赛之初赛讲解 01 计算机概述 系统基本结构_哔哩哔哩_bilibili 信息学奥赛之初赛讲解 02 软件系统 计算机语言 进制转换 信息 ...

  5. 信息学奥赛一本通习题答案(五)

    最近在给小学生做C++的入门培训,用的教程是信息学奥赛一本通,刷题网址 http://ybt.ssoier.cn:8088/index.php 现将部分习题的答案放在博客上,希望能给其他有需要的人带来 ...

  6. 信息学奥赛一本通习题答案(三)

    最近在给小学生做C++的入门培训,用的教程是信息学奥赛一本通,刷题网址 http://ybt.ssoier.cn:8088/index.php 现将部分习题的答案放在博客上,希望能给其他有需要的人带来 ...

  7. 信息学奥赛一本通 提高篇 第六部分 数学基础 相关的真题

    第1章   快速幂 1875:[13NOIP提高组]转圈游戏 信息学奥赛一本通(C++版)在线评测系统 第2 章  素数 第 3 章  约数 第 4 章  同余问题 第 5 章  矩阵乘法 第 6 章 ...

  8. 信息学奥赛一本通题目代码(非题库)

    为了完善自己学c++,很多人都去读相关文献,就比如<信息学奥赛一本通>,可又对题目无从下手,从今天开始,我将把书上的题目一 一的解析下来,可以做参考,如果有错,可以告诉我,将在下次解析里重 ...

  9. 信息学奥赛一本通(C++版) 刷题 记录

    总目录详见:https://blog.csdn.net/mrcrack/article/details/86501716 信息学奥赛一本通(C++版) 刷题 记录 http://ybt.ssoier. ...

  10. 最近公共祖先三种算法详解 + 模板题 建议新手收藏 例题: 信息学奥赛一本通 祖孙询问 距离

    首先什么是最近公共祖先?? 如图:红色节点的祖先为红色的1, 2, 3. 绿色节点的祖先为绿色的1, 2, 3, 4. 他们的最近公共祖先即他们最先相交的地方,如在上图中黄色的点就是他们的最近公共祖先 ...

最新文章

  1. linux的翻译系统开发,Linux系统下的翻译神器——Goldendict
  2. php-fpm定义成集群资源时报错解决方法
  3. 怎么找出电脑里隐藏的流氓软件_9成人都不知道的秘密!那些隐藏在你电脑里的“大象”!...
  4. 蓝牙模块音频BLE数据数传串口AT指令的使用方法
  5. 西安理工大学计算机专业毕业,西安理工大学什么专业好找工作?毕业工资大概多少?答案在这里...
  6. 【EOJ Monthly 2019.02 - A】回收卫星(交互题型,二分)
  7. 1 操作系统第一章 操作系统概念、功能、四大特征、操作系统发展与分类
  8. [简单分页]C#+JQUERY+ORACLE分页效果 ----转载
  9. 2018.11.02 洛谷P2661 信息传递(拓扑排序+搜索)
  10. NYOJ--6--喷水装置(一)
  11. 怎样访问远程服务器文件夹,远程访问服务器文件夹
  12. Rust:Programming Rust:所有权
  13. 2020年勒索病毒事件盘点及未来发展趋势
  14. 仿淘手游交易平台网站源码
  15. 计算机操作系统第四版课后题答案汤小丹
  16. viper4Android md风格,ViPER4Android音效 XHIFX版
  17. 三菱FX5U系列PLC模拟量使用方法及相关参数设置
  18. 【LeetCode - 702】搜索长度未知的有序数组
  19. 千寻位置服务器地址和端口,全球最大规模高精度定位路测,多场景力证千寻位置服务和算法...
  20. LLMs之InstructGPT:《Training language models to follow instructions with human feedback》翻译与解读

热门文章

  1. Java 输出所有的水仙花数
  2. Linux运维:现状、入门和未来之路【警醒自己】
  3. 钛资本研究院:企业服务市场资产的平衡计分卡
  4. np.repeat函数
  5. Windows环境下编译pjsip
  6. Linux文件相关指令
  7. code::blocks上方运行按钮被我点没了,怎么找回来
  8. 文章摘要生成(Summarizing Text with Amazon Reviews)
  9. nomasp 博客导读:Lisp/Emacs、Algorithm、Android
  10. 支付安全(证书/秘钥/签名)