VxWorks操作系统下实现ComPactPCI总线驱动

发布者:xi24最新更新时间:2011-09-21 来源: 国外电子元器件关键字:ComPactPCI  VxWorks 手机看文章 扫描二维码
随时随地手机看文章

1 引言

  VxWorks是美国Wind River公司专门为嵌入式处理器设计的一种模块化、高性能的实时多任务操作系统。这里提出一种VxWorks操作系统下CompactPCI总线驱动程序的设计及实现。该设计使用德国Kontron DT-64,采用Dual PentiLim 3 CPU,工作频率高达866 MHz,具有128 KB一级高速缓存和128 KB二级高速缓存。
 

  2 BSP与VxWorks的关系

  板级支持包BSP(board support packet)通常是针对具体的硬件平台,是用户所编写的启动代码和部分设备驱动程序的集合。在VxWorks操作系统中,BSP是介于底层硬件环境和VxWorks之间的一个软件接口,它的主要功能是系统加电后初始化目标机硬件、初始化操作系统及提供部分硬件的驱动程序。BSP与VxWorks之间的关系如图1所示。从图1发现,BSP不是一个设备驱动程序。它只能运行于指定设备的硬件环境中,对其进行控制和初始化。这里主要阐述在PCM发送,接收模块的设计过程中,如何利用DT-64 BSP来实现PCI总线的驱动程序。

  

 

  3 总线及接口技术

  由于CompactPCI规范定义基于PCI总线方式的复印加坚固而耐用的PCI版本,并且适用于工业和嵌入式应用,本设计采用此规范。CompactPCI总线是3种技术的集成:通用PCI局部总线(Local Bus)的高性能,安装牢固的欧卡结构,接触可靠的针孔连接器(pin-antl-soeket connector)。

  PCI局部总线是一种地址和数据复用的高性能32,64位总线,它在高度集成的外围控制器件、外围插件板和处理器/存储器之间起连接作用。PCI总线为CPU和板上外设提供了方便的高速通信连接,工作频率为66 MHz或更高。PCI作为一种同步的、独立于处理器的32 bit或64 bit局部总线,在工作频率为33 MHz总线宽度为32 bit最低规格时其峰值吞吐速率可达到132 MB/s,适用于网络适配器、硬盘驱动器、视频卡、图形卡等各类高速外设。连接到PCI总线上的设备分为主控和目标两类,PCI支持多主系统。PCI总线的一个重要特点是存在配置空间,它提供一种配置关联,适合于目前或将来的系统配置机制,实现参数自动配置。系统软件通过读取配置空间中相应参数,即可确定PCI总线上挂接了什么设备以及需要哪些资源,通过对地址空间的重定位分配资源避免竞争,实现PCI设备的即插即用。

  连接到PCI总线的用户功能板卡需要使用PCI总线接口控制器和PCI总线进行交互,在应用系统设计时采用OL5064器件。QL5064是一款32 bit/33 MHz的通用PCI总线控制器,符合PCI规范2.2版,本突发传输速率达到132 MB/s。可作为PCI总线的主控设备控制总线,也可作为目标设备响应总线。Ql5064提供了PCI总线、E2ROM、LOCAL总线3个接口。LOCAL总线支持复用/非复用的32 bit地址/数据,有3种工作模式:M、C和J。在系统实际数据采集时,将LOCAl总线设置为C模式,这是一种目标设备模式。选用NM93CS56L型串行E2PROM作为QL5064的配置器件,该器件通过E2ROM接口和QL5064相连。QL5064的长配置方式要求68个字节的信息,主要包括:设备识别号、供应商代码号、LO-CAL总线3个空间的性质、范围以及基址等,这些配置信息内容一般要预先设计并用编程器事先写入配置器件中。在计算机启动时,系统将根据配置信息分配器件所申请的资源。Q155064作为一种桥接器件,在PCI总线和LOCAL总线之间有3种主要数据传输模式:

  (1)PCI Initiator数据传输模式 主控模式,LOCAL总线主设备通过QL5064访问PCI总线存储空间和I/O空间;

  (2)PCI Target数据传输模式PCI总线主设备通过QL5064访问LOCAL总线存储空问和I/O空间;

  (3)DMA数据传输模式QL5064作为两总线的主设备,从PCI总线存储空间读数据到LOCAL总线存储空间或者从LOCAL总线存储空间读数据到PCI总线存储空间。在系统设计中,使用PCI Target数据传输模式读写控制模块中的寄存器。

4 设备的配置技术

 

  VxWorks是专门为实时嵌人式系统设计开发的操作系统软件,提供高效的实时任务调度、中断管理、实时的系统资源分配以及实时的任务间通信。程序员可将主要精力放在应用程序本身,而不用关心对系统资源的管理。

  为阐明在VxWorks操作系统下如何实现CompaetPCI总线设备的驱动,需了解PCI设备的配置寄存器空间。PCI设备有3种物理存储空间:配置寄存器空间、存储器空间和I/O空间。PCI局部总线设备中配置寄存器空间是一容量为256 KB并具有特定记录结构的地址空间,该空间分为头标区和设备有关区两部分,空间头标区的定义如图2所示。

  

 

  在配置空间中,只读空间有设备标识、供应商代码、修改版本、分类代码以及头标类型。其中供应商代码用来标识设备供应商;设备标识用来标识某一特殊的设备;修改版本标识设备的版本号;分类代码用来标识设备的种类;而头标类型用来标识头类型以及是否为多功能设备。除供应商代码之外,其他字段的值由供应商分配。

  PCI设备可以在地址空间中重定位是其重要功能之一,使得系统可合理地分配资源,甚至完全相同的两块PCI卡也能够在同一总线内工作而不会产生地址冲突。基地址寄存器的功能是分配PCI设备的系统地址空间,在基地址寄存器中,位0(最低位)均为只读位并且用来标识是存储器空间还是I/O地址空间。如果该位为0,表示映射到存储器空间。映射到I/O空间的基址寄存器宽度总是32 bit,其中位0值为1 (用硬件实现),位1为保留位并且其读出值必须为0,其余各位用来把设备映射到I/O空间。映射到存储器空间的基址寄存器可以是32 bit宽度,也可以是64 bit宽度。其中位0也要用硬件方式使其恒为0。位2和位1两位用来表示映射类型,其余各位用来将设备映射到存储器空间。

  系统配置软件通过向基址寄存器写入全“1”后再读回的方式确定设备要求的地址空间范围,与地址空间无关的位其返回值为0。

  在VxWorks操作系统下实现CompactPCI总线设备的驱动过程主要包括下面步骤:

  (1)查找CompaetPCI设备在VxWorks操作系统中通过函数peiFindDeviee()来实现,该函数可根据给定的设备标识和供应商代码找到相应的设备。并返回总线号、设备号以及功能号。函数的定义如下:

  

 

  )

  (2)配置CompactPCI设备 通过操作系统提供的API函数访问CompactPCI设备的配置空间,配置CompactPCI设备基址寄存器、中断、ROM基地址寄存器等,可得到Compact-PCI的仔储器空间和I/O地址空间映射、设备的中断号等。在VxWorks操作系统中访问CompactPCI设备配置空间的函数有pciConfigInLong()、pciConfigOutLong()等,它们分别完成对CompactPCI设备配置空间的读写操作。这一系列操作也称为PCI设备枚举。然后,根据CompactPCI设备的配置参数,对不同的设备编写初始化程序、中断服务程序以及对PCI设备存储空间的访问程序。

关键字:ComPactPCI  VxWorks 引用地址:VxWorks操作系统下实现ComPactPCI总线驱动

上一篇:基于μC/OS-II和TCP/IP协议的多串口服务器
下一篇:PCI9656实现与CPCI总线通信的雷达信号处理板

推荐阅读最新更新时间:2024-03-30 21:49

VxWorks for X86的输入输出定向
Email: jinyuhe@163.com 摘要: 此文主要介绍在嵌入式系统VxWorks中针对X86开发时标准输入输出的重定向 关键词: PC console 重定向 嵌入式系统 VxWorks 实时操作系统 RTOS 前言: VxWorks操作系统是美国WindRiver公司于1983年设计开发的一种嵌入式实时操作系统(RTOS),是嵌入式开发环境的关键组成部分。良好的持续发展能力、高性能的内核以及友好的用户开发环境,在嵌入式实时操作系统领域占据一席之地。它以其良好的可靠性和卓越的实时性被广泛地应用在通信、军事、航空、航天等高精尖技术及实时性要求极高的领域中,如卫星通讯、军事演习、弹道制导、飞机导航等。实时
[应用]
VxWorks应用技巧两例
VxWorks操作系统是一个应用比较多的实时多任务操作系统。它提供并支持多任务调度机制,用户可以将自己对事件的控制通过不同任务的协调而完成。各个任务之间通过全局变量、信号量、管道等方式进行信息交换。Wind ML是VxWorks上的一个二维图形用户界面,当多个任务都需要作画图工作时,可能出现当一个任务在正在作图时,被另一个作图任务打断,从而出现意想不到得情况。本文将介绍在VxWorks操作系统中,编写应用程序时的两个技巧。一个是内存变量保护;另一个是多任务间的画图保护。 1 全局变量的保护 各个任务之间通过全局变量交换信息时,如果其中某一任务在引用同一个全局变量期间,该变量在另一任务中被重新赋值,那么就可能发生一些意想不到的事
[应用]
探讨VxWorks实现自动发送彩信嵌入式设计
  在ARM微处理器硬件平台上,应用WindRiver公司的Tornado集成开发环境,实现基于VxWorks的自动发送彩信的嵌入式应用系统。该系统使用现有CDMA网络,根据设定的参数发送彩信到特定的移动终端用户。   随着嵌入式应用的发展和16/32位RISC处理器技术的成熟,以及支持各种高端处理器的嵌入式操作系统的涌现和完善,嵌入式无线设备可以利用CDMA网络实现许多新的应用。自动发送彩信的嵌入式系统就是这种新应用之一,在特定的条件下,系统自动发送彩信到指定的移动通信终端;该应用系统是由用户根据要求设定触发条件的自动发送彩信系统,当满足触发条件时,设备会自动控制捕获、压缩图像部件拍摄外部图像,经过模数转换、数字压缩等处理后,经
[单片机]
探讨<font color='red'>VxWorks</font>实现自动发送彩信嵌入式设计
基于S3C44BOX的VxWorks BSP设计
摘要 S3C44BOX固定的中断管理模式与VxWorks的异常处理机制存在着冲突。本文分析VxWorks的异常处理机制后,提出一种解决方案,实现VxWorks在S3C44BOX上的BSP定制。该方案保留VxWorks原有的中断处理机制,从而保证VxWorks移植后的稳定性和可靠性。 关键词 VxWorks S3C44BoX BSP 中断处理机制 引 言 VxWorks是现在所有独立于处理器的实时系统中最具特色的操作系统之一。它支持的CPU包括:PowerPC、x86、MIPS、ARM等,其微内核Wind具有任务问切换时间短、中断延迟小、网络流量大等特点,是一个具有较高性能的标准嵌入式实时操作系统。此外,VxWorks操作系统还
[应用]
基于VxWorks的BSP技术分析
VxWorks是由美国Wind River 公司推出的一种强嵌入式实时操作系统(RTOS)。它采用微内核结构,具有高可靠性、实时性、可裁减性等特点,而且支持多种CPU。VxWorks的一个重要特点是它的可移植性,应用程序编码在很大程度上与目标板的硬件和结构无关。它把所有特定的硬件功能都集成在一个称之为板级支持包BSP(Board Support Package)的库中。 目前为止Wind River公司提供的基于某一CPU 评估板的BSP 超过200个,当用户开发自己目标板的BSP时,比较简单的方法是从所提供的BSP中选一个最接近的来修改。这里提到的BSP的设计就是指这种板级的对依赖于硬件的源代码做必要的修改、增加或删除,以满
[嵌入式]
基于嵌入式操作系统VxWorks的SCSI硬盘高速记录系统
摘要:介绍了由基于VxWorks的实时嵌入式操作系统、多个SCSI硬盘阵列以及高帧频CCD数字相机构成的嵌入式高速记录系统。 关键词:VxWorks 实时 嵌入式 SCSI CCD 在一些特别的科学研究和工程应用领域,需要采用高帧频、大面阵的CCD相机以获取高质量的图像数据,用于对变化较快的观测对象的运动轨迹及其变化特性分析或实时计算。由此可产生高达50MB/s以上的实时数据流,需要持续地实时记录,以便于事后分析。 本文介绍中科院光电技术研究所针对高速实时图像记录任务的要求,专门设计开发的VxWorks嵌入式操作系统下的高速嵌入式SCSI硬盘阵列记录系统。 在本系统中采用的高帧频CCD数字相机其工作帧频为:200帧/秒,分
[嵌入式]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
最新工业控制文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved