VxWorks是美国Wind River公司开发的嵌入式实时操作系统,具有高性能、可裁减性好等特点,能支持多种微处理器(如PowerPC、X85、ARM、SPARC);自问世以来,以其良好的町靠性和卓越的实时性被广泛地应用于通信、航空、航天等高精尖技术及实时性要求极高的领域中。BSP(Board Support Package,板级支持包)的作用是针对特殊的硬件平台,为操作系统内核提供操作接口,使操作系统能够独立于底层硬件。对上层应用屏蔽具体硬件,VxWorks的高可移植性就是通过BSP实现的。AT91RM9200是Atmel公司生产的一款ARM9核芯片,本文重点介绍将VxWorks移植到该芯片过程中BSP的定制过程。
1 BSP概念
BSP通常是指针对具体的硬件平台,用户所编写的启动代码和部分设备驱动程序的集合。它所实现的功能包括初始化和驱动部分设备。最基本的BSP仅需要支持处理器复位、初始化、驱动串口和必要的时钟处理。BSP是相对于操作系统而言的,不同的操作系统对应不同形式的BSP,因此,在写BSP时一定要按照要求的操作系统对BSP的定义形式来写。在VxWorks系统中,BSP是介于底层硬件环境和VxWorks之间的一个软件接口,它的主要功能是系统加电后初始化目标机硬件和VxWorks,并提供部分硬件驱动程序。BSP在VxWorks系统中的层次关系如图1所示。
BSP为各种板卡的硬件功能提供了统一的软件接口,包括硬件初始化、中断的捕捉和处理、硬件时钟和定时器管理、内存地址映射,以及内存分配等。每个BSP还包括一个ROM启动或其他启动机制。
2 VxWorks的引导过程
在编写BSP之前,首先要了解整个系统的启动过程。VxWorks的映像由代码段、数据段和BSS段3部分组成。VxWotks内核可以分为3种:可加载类型映像、基于ROM的VxWorks映像和RoM驻留型映像。这3种类型的映像组织是不一样的,因此启动过程有所区别。
可加载映像包括VxWorks和Boot ROM两部分内容,两部分是独立创建的。首先,由系统引导代码把ROM引导程序搬到RAM_HIGH_ADRS。然后,ROM引导程序开始运行,将VxWorks映像加载到RAM_LOW_ADRS,之后跳转到VxWorks映像装入点。
基于ROM的VxWorks映像在BSP初始化时,会把lmage完全搬到RAM中执行,包括代码段和数据段。在拷贝执行完毕后,系统控制权转移给RAM中VxWorks映像的初始化代码。
ROM驻留型映像只是将ROM中VxWorks映像的数据段和BSS段拷贝到RAM中,完成后系统控制权转移给ROM/Flash里VxWorks映像的初始化代码,代码段留在ROM中并在ROM中运行。在ROM中运行的VxWorks映像主要足为了节省RAM空间,带来的不利则是运行速度慢。[page]
图2和图3分别是下载型和ROM型VxWorks映像的初始化流程。
下面以ROM型VxWorks内核启动流程为例,说明各文件的作用:
romlnit()保存启动类型,屏蔽中断;初始化内存和寄存器,屏蔽Cache;初始化CPU,将堆栈指针定位于被拷贝Boot ROM映像在RAM的地址;跳到romStart()。
roraStart()根据不同的映像类型将VxWorks映像的不同部分解压缩<如果需要)并加载到RAM中。
usrInit() 对VxWorks映像的BSS段清零;调用intVecBaseSet()设置中断矢量基地址表;调用excVecInit()初始化异常中断矢量;调用sysHwInit()初始化系统硬件;调用usrKernelInit()初始化wind内核;调用kernellnit()启动wind内核,启动usrRoot()任务。
usrRoot()设置操作系统时钟,创建设备,安装驱动,调用sysHwInit2()安装系统时钟和辅助时钟中断以及串口等设备的中断,初始化I/O、文件系统、调用应用程序。
3 VxWorks在AT91RM9200上的BSP设计
3.1 AT91RM9200简介
AT91RM9200的片上资源包括:ARM920T处理器棱、16KB的内部SRAM和128KB的内部ROM存储器;支持SDRAM、SRAM、Burst Flash和CompactFlash、SmartMedia以及NANDFlash的无缝连接;16KB的数据Cache,16KB的指令Cache,完全可编程的外部总线接口EBI,4个32位的PIO控制器可以达到122个可编程I/O引脚(每个都有输入控制、可中断及开路的输出能力);带有8个优先级、可单独屏蔽中断源的先进中断控制器、6组硬件定时器、4个通用同步/异步收发器USART。
3.2 BSP中几个重要文件的修改
由于AT91RM9200的内核是ARM920T,所以BSP文件主要在VxWorks编泽环境Tornado的目录target/config/all和target/config/integrator920t文件夹里。其中,a11文件夹里的文件对于绝大多数BSP都是共用的,一般来说不需要修改,特别是“configAll.h”;integrator920t文件夹里的文件就是所要编写的BSP文件,这些文件往往与系统硬件密切相关。
3.2.1 修改Makeflie
Makefile文件定义编译和链接整个BSP的规则,如编译工具的选择、编译选项和包含文件路径等;控制生成VxWorks映像文件的类型,同时含有存储区大小的信息,对于存储区大小信息的改动必须与Config.h的对应改动同步。有些参数需在该文件中定义,如处理器类型、编译工具、目标地址等。下面介绍一些须修改的参数和地址:
4 编译生成映像
系统定制完成后,有两种编译方式:一种是在Tornado下进行编译,生成映像文件;另一种是直接用Make工具编译,但要写好脚本文件。装载到目标板中的VxWorks映像取决于使用的下载方式,其中主要包括以下几种:
①VxWorks。这是基于RAM的映像,VxWorks需要通过目标板上的引导程序从串口或网口把它下载到目标板的RAM中运行。在Tornado开发环境下,这是一个默认选项,主要用在调试阶段。使用宿主机上的WindSh工具和符号表。
②VxWorks.st。这也是基于RAM的映像,需要通过引导ROM把VxWorks映像下载到目标机内存中才能执行。该对象文件内置符号表。
③VxWorkS_rom。这是一个非压缩、基于ROM的映像。在这个对象文件执行前,先把自己拷贝到目标机RAM中。这种类型的映像通常在启动阶段速度比较慢,因为代码在ROM中执行,但执行阶段比ROM驻留型的映像要快。
④VxWorks.st_rom。这是基于ROM压缩的VxWorks映像。它在执行前先把自己解压并拷贝到目标机RAM中执行。
⑤VxWorks.res_rom。这是ROM驻留型的非压缩VxWorks的映像。它在执行前把数据段拷贝到目标机RAM中。这种类型的映像在启动阶段比较快,但在目标机上执行的速度比基于ROM类型的映像慢(因为CPU访问ROM比访问RAM要慢)。通常在RAM空间比较小的目标机上使用这种类型的映像。
5 需要注意的问题
首先,应该避免在romInit.s中进行过多的初始化操作。该史件中只是进行必要的最小硬件初始化,大部分硬件的初始化都是在sysHwInit()中完成的。另外,romTnit.s中的代码不应当被其他模块或函数调用。
其次,应该避免sysAlib.s中工作太少。BSP开发人员通常错误地认为在romInit.s里初始化过的设备不需要在sysAlib.s中重新初始化。实际上,VxWorks映像并不认为它是由引导映像程序引导的,因此,它必须重新设置和初始化所有它自己需要使用的设备。sysInit()是该文件中最主要的一个函数,也是第一个函数。该例程中很多工作与romInit()是相同的,目的是保证内核映像在运行与冷启动时,软硬件环境高度一致。
最后,对特定的BSF。驱动程序的修改,只能在特定的BSP目录下。此设计中目录为target/config/integra-tor920t,不要直接在target/src/drv以及target/h/drv中修改。只有风河公司的源程序才能存放在这些目录下。
6 结论
本文在介绍BSP的概念、作用和vxWorks映像分类以及系统启动流程的基础上,以Atmel公司生产的ARM9处理器AT91RM9200为例,重点介绍了VxWorks的BSP设计中需要修改的几个重要文件,最后提出了需要注意的问题。尽管目标板硬件不同,BSP的实现也不尽相同,但基本思想是一样的。本设计对各类开发板的系统移植和后续的应用程序开发有一定的参考价值。
上一篇:AT91 SAM9261在GPS接收机中的应用
下一篇:基于AT91R40008的嵌入式GPRS传输终端的设计
推荐阅读最新更新时间:2024-03-16 13:09