VxworksBSP开发流程.docx
- 文档编号:23180173
- 上传时间:2023-05-15
- 格式:DOCX
- 页数:39
- 大小:219.69KB
VxworksBSP开发流程.docx
《VxworksBSP开发流程.docx》由会员分享,可在线阅读,更多相关《VxworksBSP开发流程.docx(39页珍藏版)》请在冰豆网上搜索。
VxworksBSP开发流程
VxworksBSP开发
1.板级支持包的介绍
2.VxWorks映象及启动顺序
3.VxWorks预内核初始化
4.BSP的配置
5.BSP的开发
6.VxWorks下设备驱动程序概述
板级支持包的介绍
一.板级支持包简述
在VxWorks系统中,对BSP的简单描述为:
介于底层硬件环境和VxWorks之间的一个
软件接口,它的主要功能是在系统加电后初始化目标机硬件、初始化操作系统、提供部分硬
件的驱动程序。
具体功能包括:
(1)初始化。
所谓初始化就是指从系统上电复位开始,到VxWorks开始初始化用户应
用(即系统执行到usrAppInit函数处)的一段时间内系统所执行的过程。
这个过程主要包括
三个部分的工作:
·CPU初始化。
初始化CPU的内部寄存器。
·目标机初始化。
初始化控制芯片的寄存器,I/O设备的寄存器,为整个软件系统提供
底层硬件环境的支持。
·系统资源初始化。
为操作系统及系统的正常运行做准备,进行资源初始化,如空间分配等等。
(2)使VxWorks能够访问硬件驱动程序。
这主要是指VxWorks包含必要的设备驱动程序和相关设备的初始化。
(3)在VxWorks系统中,集成了与硬件相关的软件和部分与硬件无关的软件。
二.板级支持包与VxWorks
从上面的图中,我们可以看到,BSP不是设备驱动程序,因为设备驱动程序可以访问硬
件设备,同时,相同设备的驱动程序可以不作修改的从一个环境移植到另外一个环境当中去,而BSP只能在特定的环境下面运行。
简单地说,BSP开发人员要完成两个方面的工作:
(1)完全支持BSP管理设备
(2)通用设备驱动程序的集成工作
三.BSP的组成
BSP包含的程序是提供VxWorks访问目标机硬件环境的主要接口。
BSP主要由下面几类文件组成。
1.源文件
主要是由C语言编写的代码所组成的文件,也有一小部分由汇编语言编写而成。
2.头文件
包含针对CPU板的硬件定义以及内存定位定义的文件。
3.Makefile文件
控制构造所有类型映象的文件
4.派生文件
由其他文件衍生而成的文件。
BSP的组成文件主要包含在以下四个目录里面:
·..\Tornado\target\config\all
·..\Tornado\target\config\comps\vxWorks
·..\Tornado\target\config\comps\src
·bspname
1...\target\config\all目录下的文件
这个目录下的文件作为VxWorks体系结构产品的一部分交给用户.如果不是特殊需要的
话,没有必要修改这些文件。
简单的说,config\all下的文件并不是特定BSP的一部分,而是所有BSP的公共部分。
该目录下主要包含如下几个文件:
(1)bootConfig.c
引导ROM映象的主要初始化和控制文件
.
(2)bootInit.C
bootInit.c包含引导ROM映象第二阶段初始化的代码。
该文件定义了romStart()函数,
romInit.s中的romInit()函数执行完毕后会跳转到romStart()函数。
该函数执行必要的代
码压缩和
ROM型映象的重定位。
(3)dataSegPad.c
它保证了代码段和数据段不会共享一个MMU.
(4)usrCongif.c
包含了VxWorks映象的主要初始化代码。
不同于bootInit.c文件,它是非常完整的。
(5)version.c
提供了VxWorks的版本号、构造映象的日期和时间等信息。
(6)configAll.h
设置了所有
如果需要的
VxWorks映象的默认设置。
在这个文件里定义的变量是一些通用的设置,
VxWorks映象不同于默认的设置,使用bspname目录下的config.h
文
件中定义的宏来替换这里定义的默认宏。
2.bspname目录下的文件
这个子目录包含系统或者硬件相关的BSP文件,主要由下面的一些文件组成。
(1)Readme文件
Readme文件包含了这个BSP的发布记录。
它记录了每次发布版本、修订版本和新版本上面所做的工作。
(2)Makefile和
depend.bspname
文件
Makefile文件控制使用命令行方式构造映象。
从VxWorks5.2开始,标准的make工具是
GNUmake。
BSPmake系统包含了位于target\h\make目录下的make子文件。
如果某个
相关性文件不存在,make将自动产生一个depend.bspname文件,它可以用来追踪所有
模块的相关性。
(3)Config.h文件
Config.h文件包含了所有头文件和
CPU板相关的特殊定义。
标准的
config.h
包含下面的
内容:
·BSP版本号和修订版本号
·包含configAll.h文件
·高速缓冲存储器和MMU的配置
·共享内存网络定义
·目标板上的内存地址和大小
·ROM地址和大小
·非易失性RAM
·默认的引导参数
·时间戳驱动程序支持
·外部总县地址映射
·网络设备和中断向量
·包含bspname.h文件
(4)romInit.s文件
该文件包含引导ROM和基于引导ROM的VxWorks映象的入口初始化汇编代码。
入口
点为romInit()函数,是系统加电启动后首先执行的代码。
同时它也设置了启动参数类型,
并把该参数传递给通用的romStart()函数。
如果硬件需要立即内存映射或者设置特殊的
寄存器,则在这里处理。
一个普遍的错误是BSP的开发人员企图在romInit.s文件中进行过多的初始化操作。
实
际上,大部分其他初始化操作是被推迟到sysHwInit()函数中进行的。
另外,romInit.s
件中的代码不应当被其它的函数或者模块所调用。
文
(5)sysALib.s
这个文件包含目标机体系结果所决定的、与系统有关的汇编语言程序。
当用C语言来编写,然而由于编译等原因需要用汇编语言程序编写的时候,
所有
BSP程序应
可以把所有
汇编语言编写的程序代码放在sysALib.s中。
sysALib.s文件里的sysInit()函数是VxWorks映象的入口点。
系统引导之后,首先执行该段代码。
(6)sysLib.c
这个文件包含目标机体系结构所决定的、与系统有关的C程序。
这些程序提供板极接口,基于这些板极接口,VxWorks和应用程序的构造和系统无关。
sysLib.c文件中包含了对
驱动程序的安装和初始化工作,这些工作具体在一些子文件中实现,比如sysSerial.c、
sysScsi.c、sysNet.c等。
使用子文件的目的是为了保持设备驱动程序的安装和初始化不随结构的变化而改变。
(7)sysSerial.c
SIO设备串行I/O设备驱动程序的安装和初始化
(8)sysScsi.c
包含SCSI-2设备驱动程序的安装和初始化
(9)sysNet.c
网络接口程序的安装和初始化
(10)bspname.h
与目标板有关的特殊信息的定义
(11)target.nr
这个文件了运行VxWorks必须需要的目标板特殊信息
(12)configNet.h
网络配置头文件。
主要包含END网络设备驱动程序的配置。
3...\target\config\comps\vxWorks目录下的文件
VxWorks实时内核基本模块描述文件.
4...\target\config\comps\src目录下的文件
VxWorks实时内核基本模块配置文件.
四.BSP开发
下面对BSP的开发做一下宏观上面的描述:
(1)BSP的开发步骤应当是一个逐步增加应用的过程
(2)开发过程中的软、硬件支持(ICE、BMD)
(3)开发效率的提高
(4)BSP的调试方法
·ICE调试法
仿真器
主机
映象
目标板
并口
数据线
·BDM调试法
主机
BDM适配器
目标板BDM口
并口
数据线
·黑调试法
利用亮灯、示波器等手段。
VxWorks
ICE、ROM仿真器等
五.Tornado目录结构
Tornado开发系统包含三个高度集成的部分:
·运行在宿主机和目标机上功能强大的交叉开发工具和实用程序
·运行在目标机上的高性能、可裁剪的实时操作系统·连接宿主机和目标机的连接方式,如以太网、串口线、
Tornado下的主要目录如下:
Host目录树
Target目录树
VxWorks映象及启动顺序
最小的初始化处理是由防在目标机内存特殊位置的一部分代码和可能的一些表(中断描
述表、全局描述表)组成。
当目标机复位或者加电以后,处理器总是跳转到这个位置。
这部
分代码初始化机器到某一个指定的状态上、初始化内存和内存地址、关中断,然后把控制权
交给附加引导代码。
一.VxWorks映象类型
系统把VxWorks映象的类型分成三种,各类型的影响内部又包含不同的子类型。
1.可加载(Loadable)的映象类型
可加载型映象的执行需要通过引导代码把它装载到目标机
RAM中,然后才开始执行。
而引导代码分为两中:
·引导代码固化在
ROM或FLASH中
·引导代码是一个独立的
VxWorks应用
引导代码通常也是一种
VxWorks映象,有时候称之为引导映象。
它的设计目的就是把另
一个包含应用的
VxWorks映象装入到
RAM中。
引导映象在运行时,可能在ROM/FLASH
中执行,也可能在
RAM中执行。
2.基于ROM(ROM-based)的映象类型
基于ROM型映象在执行前首先把自己从
ROM或者FLASH中装载到RAM中。
这种类型
的映象通常在启动阶段会比较慢,但是执行阶段比较快。
3.ROM驻留(ROM-Resident)的映象类型
ROM驻留型映象在启动的时候,把数据段拷贝到目标机
RAM中。
这种类型的映象通常
在启动的时候会比较快,当目标机的
RAM空间比较小的时候,通常使用这种映象。
在
嵌入式应用中通常使用这种类型的映象,
然而它在目标机上的执行速度要比其它类型的
映象要慢。
二.VxWorks映象启动顺序
在目标机加电启动时发生的顺序启动事件是一个典型
VxWorks映象需要执行的功能。
所有类型的VxWorks映象在初始化阶段启动顺序是一样的,
处理器通过”Jump”跳转指令
跳转到ROM或者Flash中引导代码的入口处,这段引导代码通常包含如下的操作:
·关中断
·初始化目标机内存
·装载适当的VxWorks映象段
·跳转到设置目标机为静止状态的代码处
1.可加载型VxWorks映象引导顺序
可加载型VxWorks映象引导的详细过程如下:
(1)数据段和代码段的装入。
系统加电后执行引导带代码,首先把引导代码的代码段和数据段从ROM或者FLASH里装到RAM中。
此时,需要考虑下面的情况:
·压缩型引导代码。
这种类型的引导代码在拷贝的时候,要对其进行解压操作。
·非压缩型引导代码。
这种类型的引导代码直接进行拷贝操作就可以了。
·驻留型引导代码。
这种类型的引导代码只拷贝它的数据段就可以了。
(2)
VxWorks映象的装入。
引导代码执行后,把
VxWorks映象装入到
RAM中,然后
跳转到VxWorks映象装入点。
(3)系统初始化。
这步操作由静态链接在VxWorks映象里的系统初始化代码来完成,最终完成系统的初始化操作。
2.基于ROM的VxWorks映象启动顺序
引导带程序
VxWorks映象
基于ROM的
VxWorks映象
基于ROM的VxWorks映象启动详细过程如下:
(1)VxWorks映象的装入。
系统加电后引导代码的执行,首先将VxWorks映象从ROM或者FLASH里装入到RAM中。
(2)
控制权转移。
VxWorks映象被装入之后,系统控制权交给
VxWorks映象中的系
统初始化代码部分
(3)
系统初始化。
静态链接在
VxWorks中的系统初始化代码在
RAM里执行,完成系
统初始化操作
3.ROM驻留型VxWorks映象启动顺序
基于ROM驻留型的VxWorks映象启动详细过程如下:
(1)
VxWorks映象的装入。
系统加电后引导代码的执行,首先将
VxWorks映象的数
据段从ROM或者FLASH里装入到RAM中。
(2)
控制权转移。
VxWorks映象被装入RAM之后,系统控制权交给
ROM/Flahs里的
VxWorks映象中的系统初始化代码部分
(3)系统初始化。
静态链接在VxWorks中的系统初始化代码执行,完成系统初始化操作
引导带程序
VxWorks代码段
VxWorks数据段
VxWorks数据段
三.典型的VxWorks映象
1.VxWorks
2.VxWorks.st
3.VxWorks_rom
4.VxWorks.st_rom
5.VxWorks.res_rom
6.VxWorks.res_rom_nosym
7.Bootrom
8.Bootrom_uncmp
9.Bootrom_res
VxWorks预内核初始化
预内核初始化主要是指CPU的初始化、向量表的安装、全局描述表的安装、目标机上硬件设备的初始化、操作系统初始化等操作。
一.预内核初始化概述
(1)下载型VxWorks映象预内核的初始化顺序
目标机系统加电后,首先执行VxWorks引导程序,由引导程序把VxWorks映象装载到目标机RAM中。
当把VxWorks映象装入到RAM之后,处理器跳转到映象装入地址处。
接下来首先执行sysInit()函数,然后执行usrInit函数,由usrInit()函数彻底完成整个预内核的初始化。
(2)ROM型VxWorks映象预内核的初始化顺序
目标系统加电后,首先执行romInit()函数,其功能是对
romStart()函数进行映象段的拷贝和解压缩工作,然后执行
CPU进行初始化,然后执行
usrInit函数,由usrInit()
函
数彻底完成整个预内核的初始化。
二.预内核的特殊初始化函数
VxWorks映象里的特殊函数如下:
·romInit()函数
·romStart()函数
·sysInit()函数
romInit()函数和
romStart
函数是所有固化在
ROM/Flash
里的
VxWorks映象(
ROM型
VxWorks映象)所必须执行的函数,而
sysInit()
函数仅仅只是所有装载型
VxWorks映象执
行的函数。
1.romInit()
函数
(1)romInit()函数功能简述
romInit()函数包含在romInit.s文件中,且用汇编语言编写。
它是系统加电后首先执行的代码,也是所有ROM型VxWorks映象入口点。
它执行目标机最小的初始化操作及调用romStart()函数。
romInit()函数必须包含下面的功能:
·屏蔽处理器中断和处理器复位
·初始化系统内存
·初始化堆栈指针和其他寄存器,开始执行romStart()函数及传递启动参数
(2)冷启动和热启动
冷启动是指硬件环境通过加电启动。
在romInit()函数中需要保存系统启动类型,启动类型的宏定义为BOOT_COLD。
热启动是指通过调用reboot(),Ctrl+X或者异常中断等重新启动目标机系统的方式。
2.romStart()函数
romStart()函数是所有固化在ROM/Flash里VxWorks映象第一个执行的C语言函数。
(1)romStart()函数的功能描述
romStart()函数包含在../all/bootInit.c文件中,并且用C语言编写成。
它是系统最
先执行的一个C语言程序,为ROM映象执行必要的代码重定位、解压缩和RAM初始化操作,
具体如下:
·拷贝适当的ROM映象段到RAM中
·清理没有被使用的那部分内存
·执行解压缩操作(如果有必要)
·调用预内核的通用初始化程序usrInit()
(2)romStart()的修改
在BSP的开发过程中,可能需要修改
bootInit.c
文件。
这个文件是
BSP的一个公用文
件,所以对于该文件的修改,情况比较特殊,具体步骤如下:
·拷贝bootInit.c
文件。
bootInit.c
文件是一个公用文件,所以不可以直接修
改..config/all
目录下的bootInit.c
文件,而是应该把该文件拷贝到某个
BSP目录下,然
后修改这个BSP目录下的bootInit.c
文件。
·修改makefile文件。
为了链接拷贝的
bootInit.c
文件,而不是原始的文件,需要修改
BSP目录下的makefile
文件。
在HEX_FLAGS宏定义后面增加一行:
BOOTINIT=bootInit.c
在构造VxWorks映象的控制文件rules.bsp
文件中,系统通过使用
BOOTINIT宏定义来访问
bootInit.c
文件。
这个宏定义的默认的访问的值是
../config/all/bootInit.c
文件。
(3)romStart()配置宏定义
(4)ROM和RAM的布局
3.sysInit()函数
(1)sysInit()函数功能描述
sysInit()函数是装载型VxWorks映象的入口点。
当映象被装载到RAM中以后,处理器
将跳转到sysInit()函数处执行。
该函数原形在sysAlib.s中,是用汇编语言编写成的。
当映象被装载到RAM中,sysInit()函数驻留在装载型VxWorks映象的装载地址处。
它
执行必须的最小初始化操作以及调用usrInit()函数,而硬件初始化推迟到预内核通用初始
化代码中进行。
(2)sysInit()代码的获得
sysInit()函数的代码可以通过修改romInit()函数的代码获得,仅仅需要修改一些便
可以得到sysInit(0函数代码:
·删除内存初始化代码
·把调用romStart()函数改为调用usrInit()函数
·sysInit()函数在RAM中执行,所以不需要设计成与地址无关的代码(3)RAM布局
三.预内核的通用初始化代码
1.通用初始化代码概述
(1)通用初始化代码的职责
·通用初始化代码必须为VxWorks内核提供一个环境,以便激活VxWorks内核
·内核代码执行后,初始化系统需要的系统内存空间或者多任务环境
(2)通用初始化
预内核的通用初始化操作是通过usrInit()进行的,该函数是用C语言编写的。
其原型
函数包含在usrConfig.c文件中。
当构造VxWorks文件的时候,它被静态链接到映象中。
系
统调用该函数也就激活了VxWorks内核。
而初始化硬件的操作,主要是通过调用sysHwInit()函数来实现的,该函数主要包含主
要功能如下:
·屏蔽所有硬件设备的中断
·初始化硬件设备到可知的静止状态
BSP的配置
用户在开发自己的目标机BSP之前,必须了解在VxWorks操作系统下BSP的配置,只有在熟悉BSP的配置之后才可以正确对BSP进行移植和修改工作,并根据自己的需要成功的配置一个BSP。
一.BSP的基本配置
(1)ROM和RAM布局
用户可以根据目标机的具体情况对ROM和RAM的空间布局进行配置,配置过程主要是通过修改地址宏定义的值而达到的,在config.h文件中定义了这些宏。
在修改这些宏的时候,需要注意的是,同时也将makefile文件中定义的宏做对应的修改。
(2)内存配置
内存配置包括用户驻留程序的内存基地址、局部总线内存基地址、内存基地址以及内存大小等。
(3)启动设备及参数配置
启动设备及参数配置主要包含引导参数的配置,即从哪里下载VxWorks映象、系统热启
动之后从什么设备上启动系统以及设备相关的其它参数的配置:
·默认引导参数配置
·热启动设备和参数配置
(4)外围设备驱动程序及相关参数的配置·配置TrueFFS驱动程序·配置软盘驱动程序·并行端口驱动程序·时钟配置
·浮点处理支持·硬盘配置·串口配置
(5)文件系统配置
(6)网络驱动程序配置
(7)高级缓存配置
(8)堆栈配置
二.VxWorks的基本配置
(1)内核软件的配置
(2)内核软件工具的配置
(3)内核软件扩展工具的配置
VxWorks下设备驱动程序概述
VxWorks下的设备驱动程序在设计上继承了常规驱动程序的设计,同时也包含了自己的独到之处。
VxWorks下的设备驱动程序都以模块为单位、各个模块之间功能明确、接口规范。
VxWorks设备驱动程序是一个直接控制下层设备的上层软件接口。
一.VxWorks下常用设备驱动程序源文件
如下:
二.VxWorks下设备驱动程序的配置
配置VxWorks下系统自带的设备驱动程序,是一个非常简单的事情,
中找到驱动对应的宏,就可以把设备驱动程序添加到系统中了。
只要在相关的文件
在bspname目录下,可以找到config.h文件,在这
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- VxworksBSP 开发 流程