`
Gavin.Chen
  • 浏览: 326471 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

[转载] Boot Loader的启动流程和开发经验总结

阅读更多

[转载于] http://blog.21ic.com/user1/5585/archives/2009/56077.html

作者 xgywinner 日期 2009-3-4 8:55:00

Windows CE最大程度继承了桌面版Windows的丰富功能,但是Windows CE并不是一个通用的安装版操作系统。在形形色色的嵌入式设备世界里,一款CE系统通常只会针对某一种硬件平台生成。

  一般来说,Windows CE的开发过程可以分为:0AL(OEM Abstraction Layer)、驱动、应用程序开发三个步骤。其中,0AL开发最基本的一步是板级支持包(BSP),而BootLoader设计则在BSP开发中具有极为关键的地位。


  1.什么是BootLoader

  嵌入式系统的启动代码一般由两部分构成:引导代码和操作系统执行环境的初始化代码。其中引导代码一般也由两部分构成:第一部分是板级、片级初始化代码,主要功能是通过设置寄存器初始化硬件的工作方式,如设置时钟、中断控制寄存器等,完成内存映射、初始化MMU等。第二部分是装载程序,将操作系统和应用程序的映像从只读存储器装载或者拷贝到系统的RAM中并执行。

  (1)什么是板级BSP?
  BSP(Board Support Package)是板级支持包,是介于主板硬件和操作系统之间的一层,主要是为了支持操作系统,使之能够更好的运行于硬件主板。不同的操作系统对应于不同形式的BSP,例如WinCE的BSP和Linux的BSP相对于某CPU来说尽管实现的功能一样,可是写法和接口定义是完全不同的。所以,BSP一定要按照该系统BSP的定义形式来写,这样才能与上层OS保持正确的接口,良好的支持上层OS。

  (2)什么是Boot Loader
  在BSP中有一个重要的组成部分就是BootLoader,它是在操作系统内核运行之前运行的一段小程序。通过这段小程序,可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,为调用操作系统内核准备好环境。

     一般来说,在嵌入式世界里BootLoader 是严重地依赖于硬件的,因此想建立一个通用的 BootLoader 几乎是不可能的。不同的 CPU 体系结构有不同的BootLoader,而且除了依赖于 CPU的体系结构外,BootLoader还依赖于具体的嵌入式板级设备的配置。这也就是说,对于两块不同的嵌入式板而言,即使它们是基于同一种 CPU 结构而构建的,要想让运行在一块板子上的 BootLoader 程序也能运行在另一块板子上,通常也都需要修改 BootLoader 的源程序。

  2.BootLoader在PC机与嵌入式的区别比较

  (1)引导程序在PC机和嵌入式上的区别
  一般来说,在PC的硬件平台上,由于硬件启动根本就不是通过BootLoader(而是通过BIOS),所以BootLoader就不需要对CPU加电后的初始化做任何工作。在桌面系统中,有以下几种设备可以作为启动设备使用:硬盘、USB盘、光盘驱动器、还有网卡的Boot ROM等。但无论选择了哪一种启动设备,操作系统都会去将该设备起始地址的内容读入内存,BIOS将控制移交给引导装载程序。如果启动设备是IDE硬盘,这时通常将引导装载程序装入第一个扇区(通常被称做主引导扇区,MBR),然后将内容读入内存再运行。

  在嵌入式平台上,引导装载程序是在硬件上执行的第一段代码,通常将引导程序放置在不易丢失的存储器的开始地址或者是系统冷启动时PC寄存器的初始值。在嵌入式系统中,通常并没有像BIOS那样的固件程序,因此整个系统的加载启动任务就完全由BootLoader来完成,引导程序完成自己的任务后,也将控制权移交给操作系统。因此,BootLoader是最先被执行的程序,所以就必须包括加电初始化程序。

  (2)BSP在嵌入式和桌面Windows中的区别
其实运行在PC机上的桌面Windows或Linux系统也是有BSP的,只是PC机均采用统一的X86体系架构,这样操作系统的BSP相对X86架构是单一确定的,不需要做任何修改就可以很容易支持OS在X86上正常运行,所以在PC机上谈论BSP这个概念也就没什么意义了。

  而对嵌入式系统来说情况则完全不同,目前市场上有多种结构的嵌入式CPU(如X86,ARM,MIPS等),而且为了性能的需要,外围设备也会有不同的选择和定义。因此,一个嵌入式操作系统针对不同的CPU会有不同的BSP,又即使同一种CPU,由于外设的差别其BSP也会不一样。所以根据硬件设计编写和修改BSP,是保证嵌入式系统正常运行的一个重要环节。

  (3)嵌入式BSP与PC机主板BIOS的区别
  PC机主板上的BIOS首先是负责在电脑开启时检测、初始化系统设备、装入操作系统并调度操作系统向硬件发出的指令。它的Firmware代码是在芯片生产过程中固化的,一般来说用户是无法修改。然后,为下载运行操作系统做准备,把操作系统由硬盘加载到内存,并传递一些硬件接口设置给系统。在OS正常运行后,BIOS的作用基本上也就完成了,这就是为什么更改BIOS一定要重新关机开机。

  从这个角度来说,PC机BIOS的作用就象嵌入式系统中的Bootloader,都是最底层的引导软件,初始化主板的基本设置,为接收外部程序做硬件上的准备。但与Bootloader不同的是,BIOS在装载OS系统的同时还传递一些参数设置,而Bootloader只是简单的装载系统。尽管BSP的开始部分和BIOS所做的工作类似,可是大部分又和BIOS不同,作用也完全不同。因为BSP还包含和系统有关的基本驱动,程序员可以编程修改BSP,在BSP中任意添加一些和系统无关的驱动或程序,甚至可以把上层开发的统统放到BSP中。而BIOS程序是用户不能更改和编译编程的,只能对参数进行修改设置,当然更不会包含一些基本的硬件驱动。

  3.Boot Loader的启动流程

  大多数 BootLoader 都包含两种不同的操作模式:启动加载模式和下载模式。启动加载模式也称为自主模式,即 BootLoader 从目标机上的某个固态存储设备上将操作系统加载到 RAM 中运行,整个过程并没有用户的介入。而下载模式则是目标机上的 BootLoader 将通过串口连接或网络连接等通信手段从主机(Host)下载文件。从主机下载的文件通常首先被 Boot Loader 保存到目标机的 RAM 中,然后再被 BootLoader 写到目标机上的FLASH 类固态存储设备中。这种模式通常在第一次安装内核与根文件系统时被使用,或系统更新时使用。一般嵌入式系统的Boot Loader较为常用的是启动加载模式,它的加载流程也是我们要重点讨论的内容。

  (1)启动部分
  启动部分主要是实现初始化硬件的功能。在参考板的BootLoader目录下,会发现一些.s文件,可能会是init.s或者是reset.s等,这样的文件是CPU加电后最先执行的代码。接着Oal.exe通过Startup函数完成硬件的初始化,StartUp 函数是Boot Loader的入口函数。该函数一般是使用汇编语言编写,与CPU关系非常紧密,能完成初始化CPU、内存等核心硬件。

  Startup.s代码与硬件平台的Bootloader启动代码共用。如果是热启动,即在该函数调用之前已经启动了Bootloader程序,相当基本硬件初始化已经完成,则直接跳转到OALStartUp函数中;否则需要进行硬件中断屏蔽、内存、系统时钟频率、电源管理等硬件的基本初始化过程。在系统硬件初始化完毕之后,Startup调用OALStartUp函数,OALStartUp函数主要完成将OEMAddressTable表传递给内核,然后调用KernelStart函数跳转到内核。因此,这部分工作是BootLoader的一大重点。

  (2)主控部分
StartUp 函数初始化CPU等核心硬件并跳转到Main函数后,系统就会转入C语言代码执行环境。这时函数分为3个模块:BLCOMMON、Download 、FLASH 。其中BLCOMMON模块是由微软提供的,执行一些逻辑上的功能,因此建议开发人员不要对其进行修改。而Download 、FLASH 中的函数与硬件平台息息相关,因此对于每种硬件平台都要将函数的实现进行修改。

  其中,BLCOMMON库是与BootLoader程序链接在一起的,BLCOMMON库的入口点为BootloaderMain函数,它是Startup汇编函数完成后跳转至该入口的。Main函数的主要任务时调用BLCommon中的 BootloaderMain()函数,这是BootLoader的主控函数,它控制了BootLoader的完整执行流程。这部分代码由C语言实现,是BLCOMMON代码的一部分,它可以用来执行比较复杂的操作。比如检测内存和Flash的有效性、检测外部设备接口、检测串口并且向已经连接的主机发送调试信息、通过串口等待命令、启动网络接口、建立内存映射等汇编无法完成的工作。
 
  (3)下载部分
  一般在平台调试完毕后,可以在不用人工干预的情况下自动加载CE,这也是BootLoader的功能之一。而在调试阶段时,这需要通过Loader所支持的命令来进行操作的,借助于这些命令不仅可以完成硬件平台的部分测试,还能完成CE的BootLoader程序最为重要的一个功能--下载CE映像。如果说硬件调试功能可以由其它的程序代替而不放入BootLoader中,但是下载映像文件却是BootLoader必需的功能。

  CE映像文件通常叫做nk.bin,它是Windows CE二进制数据格式文件,不仅包含了有效的程序代码,还有按照一定规则加入的控制信息。当然,也可以选择生成.sre格式的代码文件,但是相于对前一种格式,它的代码要长很多,所需要的下载时间也更长。

  (4)支持DOC部份
对于WinCE操作系统而言,丰富的多媒体功能是其一大特点。但是随之而来的问题是,如果选择了图形界面和中文支持,系统很容易大大超出嵌入式系统上百KB的数量级。而DOC(Disk On Chip)则提供了一种相对廉价的大存储容量的解决方案。

  DOC本质上是一种加以软件控制的NAND格式的Flash,通过TFFS这一软件层提供对WinCE的支持。由于DOC不能像内存一样被直接访问,所以其加载WinCE的过程有些特殊,必须要在BootLoader中加入专门的代码,才能使用DOC来存放WinCE映像文件。

  4.Boot Loader的开发经验总结

  (1)嵌入式系统中,Bootloader的意义与作用与PC上的BIOS有点类似,它对开发板上的主要部件如CPU、SDRAM、FLASH、串口等进行了初始化,也可以使用Bootloader下载文件到开发板和启动系统等。因此,一个功能比较强大的Bootloader已经相当于一个微型的操作系统了。

  (2)从CE的BootLoader开发流程可以看出,BootLoader在完成下载CE映像和加载映像的主要功能外,还具有一些调试硬件的功能。当然,这些功能不是必需的,随不同的用户有不同的定义,但这是在开发CE系统中不可跳过的一环。

  (3)嵌入式系统应用开发不同于PC机,其开发过程同时涉及软硬件以及上层应用开发综合考虑;而PC机应用开发是建立在已经定制好的硬件和操作系统平台上,开发者只需调用系统提供的接口和服务完成相应的功能。考虑到成本约束,嵌入式系统的硬件平台通常是根据应用量身定制,通常所用的MPU、存储器、外围设备等有多种选择余地,使平台的引导设计变得十分复杂。因此,从零实现的话会需要相当长的过程,通常的做法是利用微软为每种类型CPU提供的标准开发板的BootLoader例程,从这些例程中寻找与硬件平台最接近的作为标本程序,然后根据硬件平台作相应的改动。

  总而言之,BootLoader是开发WinCE系统第一步,也是关键的一步。只有得到一个稳定工作的Loader程序,才能够进一步开发WinCE的BSP,才能得到整个嵌入式系统的成功。
分享到:
评论

相关推荐

    Boot Loader的启动流程开发经验总结

    ### Boot Loader的启动流程开发经验总结 #### 一、Boot Loader概述 Boot Loader是嵌入式系统中极其关键的一部分,它的主要职责是在操作系统内核运行之前执行一系列的硬件初始化操作,为操作系统创建合适的运行环境...

    Boot Loader的启动流程和开发经验总结

    Boot Loader 的启动流程和开发经验总结 Boot Loader 是一个小程序,在操作系统内核运行之前执行,负责初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,为调用操作系统内核准备好...

    嵌入式系统Boot Loader启动全过程详解.docx

    Boot Loader 的框架结构可以分为四个方面:Boot Loader 的概念、Boot Loader 的主要任务、Boot Loader 的安装和 Boot Loader 的启动过程。 5. Boot Loader 的安装 Boot Loader 的安装媒介可以是固态存储设备,如 ...

    Boot_Loader启动过程

    Boot_Loader启动过程,非常好的资料,强烈推荐

    嵌入式系统Boot Loader 技术内幕

    - Boot Loader启动过程可以是单阶段或多阶段。多阶段设计提供了更复杂的功能和更好的可移植性。常见的Boot Loader如U-Boot采用两阶段加载,第一阶段负责基本硬件初始化,第二阶段加载内核和文件系统。 5. Boot ...

    Boot Loader 技术内幕.doc

    总的来说,Boot Loader是嵌入式系统启动过程的关键,它为操作系统的启动提供了必要的环境和条件。理解Boot Loader的工作原理和实现细节对于开发和调试嵌入式系统至关重要,尤其是在定制和优化系统性能时。

    嵌入式系统 Boot Loader 技术内幕

    ### 嵌入式系统 Boot Loader 技术内幕 #### 引言 随着技术的发展,...通过对 Boot Loader 的深入了解和技术实践,可以有效提升嵌入式系统的启动速度、可靠性和安全性,进而推动嵌入式应用领域的技术创新和发展。

    Linux下Boot Loader的设计与实现

    一个成熟的Boot Loader产品应当具备易用性、稳定性和可扩展性,能够支持多种操作系统和硬件平台,并且提供完善的用户文档和开发指南。 总结而言,Boot Loader是嵌入式Linux系统设计中的关键组件,它直接关系到整个...

    基于ARM嵌入式系统的Boot Loader启动分析与移植.pdf

    通过深入研究Boot Loader的启动过程和移植方法,开发者可以更好地理解嵌入式系统的启动机制,从而优化系统性能,提高产品的可靠性。对于初学者来说,掌握Boot Loader的使用和定制技巧,有助于解决在搭建嵌入式操作...

    嵌入式系统 Boot Loader 技术内幕.rar_System bootloader _boot loader_embedd

    嵌入式系统Boot Loader技术是理解嵌入式设备启动过程的关键。Boot Loader是系统启动时运行的第一段程序,它的主要任务是加载操作系统到内存中并启动操作系统。在深入探讨Boot Loader之前,先来理解一下什么是Boot ...

    不同Boot Loader之间模块移植的实现

    在嵌入式系统开发中,不同Boot Loader之间的模块移植是一种有效提高开发效率的方法。通过对RedBoot与U-Boot之间模块移植的具体案例分析,我们可以看到这种方法不仅降低了开发难度,还显著缩短了开发周期。此外,这种...

    LPC2000系列单片机boot loader

    【LPC2000系列单片机boot loader】是嵌入式系统开发中的一个重要概念,主要用于设备在上电或复位时初始化硬件资源、加载应用程序到内存并执行。LPC2000系列是由NXP(原飞利浦半导体)推出的基于ARM7TDMI核的微控制器...

    RAppID_Boot_Loader_Utility_v1.6.7.35

    RAppID_Boot_Loader_Utility_v1.6.7.35是一款专为LIN(Local Interconnect Network)总线系统设计的Boot Loader开发工具,旨在简化LIN设备的固件更新和调试过程。 首先,我们来理解一下LIN总线系统。LIN是一种低...

    Boot-loader (vivi)源码分析.doc

    Boot Loader 是嵌入式系统启动过程中的关键组件,它的主要任务是初始化系统硬件,加载操作系统内核,并传递必要的参数。...对于理解和开发针对特定硬件平台的Boot Loader,理解这些基本概念和流程至关重要。

    Keil C51 Boot Loader 与固件制作教程

    分为两个工程,固件工程和BOOT_LOADER工程。以中颖的SH79F1612A为例,BOOT_LOADER工程生成的.hex文件烧录至BOOT_LOADER区(用户自行划分,但必须从0x0000开始,本例取0x0000到0x0fff);那么固件工程生成的.hex文件...

    芯唐NUC501 Boot Loader 应用范例

    本篇文章将详细介绍如何为NUC501设计和实现Boot Loader,并提供相应的流程与源代码示例,帮助读者理解整个开发过程。 #### 2. 为何需要Boot Loader? Boot Loader通常具备两个核心功能:加载应用程序与更新应用...

Global site tag (gtag.js) - Google Analytics