bootloader刷写流程 bootloader( 二 )


关于bootloader是什么意思的相关内容就介绍到这里了 。

bootloader刷写流程 bootloader

文章插图
bootloader功能1 初始化硬件 , 包括CPU、内存、总线、硬盘、主板以及主板上的各种设备
2 验证image , 实现可信启动
3 提供加载选择
4 加载操作系统(例如将硬盘中的操作系统拷贝到内存中)
5 将硬件的控制权转移给操作系统
6 更新各种image
7 各种维测功能
芯片公司在bootloader上增加功能用于验证芯片设计、工厂筛选芯片
开源的bootloader有:ATF(arm主导)、edk II(Intel主导)、UBoot
bootloader初识作为一个嵌入式工程师 , 如果不能写bootloader程序 , 那就不能成为一个真正的嵌入式工程师 。最近在做arm项目 , 也会用到uboot , 但是对于bootloader , 我还是处于一知半解的状态 。。
要了解arm的bootloader , 得先了解arm体系结构 。arm主要由arm内核单元 , vector interface , coprocessor , 两种cache(指令和数据cache) , 两种TCM(指令和数据TCM) , MMU(内存管理) , power management(电量管理) 。
cache是为了平衡数据之间的速度而使用的 , TCM则是为了存储一些频繁使用的数据 , 如中断向量等 。TCM和cache是有区别的 , 虽然都是为了加快速度 , 但是TCM必须给它指定地址 。TCM和cache的用途也不一样 , TCM保存常用到的数据如中断向量和realtime数据 , 而cache只是为了加快处理器和外设之间的数据处理 。
MMU主要处理虚拟地址到物理地址的转换 , 起到对数据的保护作用 , 用在操作系统的体系中 。
很显然 , bootloader程序就是要对后来的程序提供一个良好的运行环境 , 这里对arm architecture的几个组成单元进行必要的配置 。
对于嵌入式系统 , Bootloader是基于特定硬件平台来实现的 。因此 , 几乎不可能为所有的嵌入式系统建立一个通用的Bootloader , 不同的处理器架构都有不同的Bootloader 。Bootloader不但依赖于CPU的体系结构 , 而且依赖于嵌入式系统板级设备的配置 。对于2块不同的嵌入式板而言 , 即使它们使用同一种处理器 , 要想让运行在一块板子上的Bootloader程序也能运行在另一块板子上 , 一般也都需要修改Bootloader的源程序 。
反过来 , 大部分Bootloader仍然具有很多共性 , 某些Bootloader也能够支持多种体 系结构的嵌入式系统 。例如 , U-Boot就同时支持PowerPC、ARM、MIPS和X86等体系结构 , 支持的板子有上百种 。通常 , 它们都能够自动从存储介质上启动 , 都能够引导操作系统启动 , 并且大部分都可以支持串口和以太网接口 。
bootloader是什么 Bootloader是什么意思?Bootloader是什么意思?最近就有网友问到这个问题 , 简单来说它属于安卓系统的一种模式 , 下面电脑百事小编为新手朋友科普一下bootloader到底是什么 , 有何用 。
Bootloader
从字面意思来看 , bootloader
是一个英文单词 , 中文含义为
「引导装载程序」,「引导模式」等 。而日常我们一般提到这次 , 主要跟安卓手机有关 , 下面我们来看看专业的释义 。
Bootloader是什么意思?
在嵌入式操作系统中 , BootLoader是在操作系统内核运行之前运行 , 它可以初始化硬件设备、建立内存空间映射图 , 从而将系统的软硬件环境带到一个合适状态 , 以便为最终调用操作系统内核准备好正确的环境 。
在嵌入式系统中 , 通常并没有像BIOS那样的固件程序(注 , 有的嵌入式CPU也会内嵌一段短小的启动程序) , 因此整个系统的加载启动任务就完全由BootLoader来完成 。在一个基于ARM7TDMI
core的嵌入式系统中 , 系统在上电或复位时通常都从地址0x00000000处开始执行 , 而在这个地址处安排的通常就是系统的BootLoader程序 。
简单来说 , BootLoader就是在安卓操作系统内核运行之前运行的一段小程序 。通过这段小程序 , 我们可以初始化硬件设备、建立内存空间映射图 , 从而将系统的软硬件环境带到一个合适状态 , 以便为最终调用操作系统内核准备好正确的环境 。

秒懂生活扩展阅读