嵌入式系统中PCI总线仲裁器的设计与实现_第1页
嵌入式系统中PCI总线仲裁器的设计与实现_第2页
嵌入式系统中PCI总线仲裁器的设计与实现_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、    嵌入式系统中PCI总线仲裁器的设计与实现    嵌入式系统中PCI总线仲裁器的设计与实现    类别:嵌入式系统                              &

2、nbsp来源:电子技术应用 作者:中国科学技术大学 李德升 罗玉平        &nbsp摘要:描述了PCI总线仲裁的原理和仲裁算法,阐述了用可编程器件实现总线仲裁的具体方法,并实现了一个双主设备仲裁器。        &nbsp关键词:PCI总线仲裁CPLD VHDL嵌入式系统         &nbspPCI(Peripheral Component Int

3、erconnect)总线是现今最为流行的工业控制总线之一。它广泛地应用在计算机中,并且由于众多厂商对PC的良好支持,使得目前嵌入式设备中的很多解决方案都包含了PCI总线。在多主设备的PCI系统应用中,必须为各个主设备提供仲裁授权信号。很多厂家有针对性地发布了PCI仲裁逻辑的专用芯片或者集成了PCI仲裁逻辑的专用芯片,但使用不够灵活。为了使PCI设备能够更方便地应用在嵌入式系统中,本文介绍了一种基于CPLD(复杂可编程逻辑器件)的PCI总线仲裁器的设计方法。此方法可以为系统量身定制适合于系统本身的PCI总线仲裁器,而不必局限于特定芯片的要求,在体积、功能、成本等诸多方面都有很好的应用前景。

4、60;       &nbsp1 PCI总线仲裁简介   &nbsp11 PCI总线的仲裁原理   &nbspPCI总线是一种共享式的总线,可以连接多个主设备,但由于数据传输的独占性,每一时刻只能由一个主设备占用总线。因此,为了有效地利用PCI总线带宽,必须设置一个总线仲裁器,按照一定的算法协调系统中各个主设备的操作。   &nbsp每个具备主设备功能的PCI设备必须提供两个与仲裁有关的信号:REQ#和GNT#。其

5、中REQ#为请求总线信号,由需要发起PCI传输事务的设备发出;GNT#为总线授权信号,由PCI总线仲裁器裁决后给出。接到GNT#信号的PCI设备将在下一次总线空闲后   &nbsp开始操作。   &nbspPCI总线仲裁的裁决过程可以在PCI传输期间完成,并不占用PCI总线的带宽,这称为隐式仲裁。即需要发起PCI操作的设备可以随时发出请求REO#,PCI仲裁器立即批准该请求并给出GNT#。但是真正的传输操作一定要等到当前传输完成,即总线空闲后才可以开始。图l描述了PCI总线设备与仲裁器的关系。  &

6、#160;          &nbsp12 PCI总线仲裁规则约定    (1)仲裁器的仲裁算法必须保证所有的设备都能得到授权的机会,否则将会出现某个优先级低的设备永远不能占有总线进行事务操作的情况。    (2)如果FRAME无效,GNT可以在任意时间撤消,以便服务于另一个主设备或者作为对主设备撤销REQ的响应。    (3)如果GNT信号被撤消但FRAME有信号,当前的总线正在传输数

7、据,则操作合法。    (4)如果总线不处于空闲状态,则允许一个GNT的撤消和另一个GNT的发生在同一个周期。如果处在空闲状态,则要求一个GNT撤消到下一个GNT的发出之间必须有一个时钟周期间隔,否则可能会在AD线和PAR线上出现冲突。    (5)GNT信号的每次发出,只限于相应的总线主控器可以使用总线进行一次总线操作(一个FRAME发出到撤销)。如果该主控器需要多次总线访问,它可以保持REQ信号一直有效。仲裁器会按照特定的仲裁算法来决定是否仍判给该主设备。    (6)一

8、个主控器可以在任意时刻撤消其REQ信号。REQ信号一旦撤消,仲裁器将认为该设备不再请求使用总线,因而撤消其GNT信号(参考上文(1)。如果一个主控器只希望做一次总线传输,则它应当在发出FRAME的同一时钟周期撤消REQ。    (7)如果当前的主控器在它的GNT信号发出后,持续16个空闲周期还没有开始总线操作,则仲裁器视其为超时,仲裁器可以在任意时刻撤消GNT信号,以便服务于另一个设备。       &nbsp13 PCI总线仲裁的算法   &am

9、p;nbsp目前,应用于PCI总线总裁的算法主要有固定优先级算法和动态优先级算法两种。在固定优先级算法中,各个设备的优先级是事先确定好的,仲裁器针对事先设定好的优先级为每个设备分配使用权。这种算法的缺点是:一旦PCI总线事务非常繁忙,优先级高的设备会占有总线不放,将导致优先级低的设备无法申请到总线。可见这是一种并不公平的算法,只适用于总线利用率非常低的情况。动态优先级算法是在每次仲裁授权后动态改变各个设备的优先级。在保证每个设备都有机会获得总线的情况下,优先级改变的算法可以是各种各样的。最常用的是循环优先级算法,即每次仲裁授权后将排队中的设备优先级加l。因其算法简单,且对大部分应用都十分有效,

10、本设计采用循环优先级算法。       &nbsp14 总线停靠   &nbsp当PCI总线空闲时,一个设备从申请总线到被授权使用,最少也需要2个时钟周期,这对于PCI总线是一种浪费。因此仲裁器通常选中一个最经常占用总线的设备,在PCI总线空闲时将GNT#赋予它,这叫做总线停靠。当总线空闲时,该设备需要占用总线时可马上得到批准。        &nbsp2 双主设备PCI总线仲裁器的实现 &#

11、160; &nbsp下面描述了一个具有两个设备的总线仲裁器的硬件实现,其一为TriMedia嵌入式DSPCPU PNXl300,其二为Intel i82559网络控制器。系统结构如图2所示。             &nbsp为设计方便起见,在程序中设计三类状态机:总线状态状态机、总线主设备查询状态机、仲裁状态机。       &nbsp21 总线状态状态机  &

12、#160;&nbsp总线状态状态机用于记录总线事务的状态定义如下:   &nbsptype bus_state is(IDLE,BUSY,LAST_DATA,FINISH)   &nbsp四种状态分别表示总线空闲、忙、最后一个数据传输期以及传输完成。状态图如图3。             &nbsp下面是以VHDL代码形式实现的该状态机的状态转换关系。   

13、0;             &nbsp22 总线主设备查询状态机   &nbsp总线主设备查询状态机用来决定当前是否需要重新指定一个主设备。重新指定一个主设备的条件是:(1)当前被授权的设备已开始传输;(2)当前被授权的设备没有开始传输并且超时。将主设备查询状态分为IDLE、GNTl、GNT2、WAIT_NOBUSY和WAIT_BUSY2五个状态,并设置计数器count。当总线上某个设备被授权,但16个周期仍然没有开始操作,count超过

14、16,被视为超时,仲裁器可以撤销其仲裁授权,并转授其他设备。程序根据这个状态机的输出结果决定仲裁状态机是否改变。        &nbsp状态转换如图4所示,状态机描述的VHDL代码略。             &nbsp该状态机的驱动条件是由总线状态状态机的输出结果(busbusy)、仲裁状态机的状态(idie,park)和计数器产生的超时信号(timeout)组成。设置WAIT_BUSY2的目的是

15、为了避免可能会在AD线和PAR线上出现的冲突。该状态机的输出search_master作为仲裁状态机状态转换使能信号,只有该信号有效时,仲裁状态机才进行当前状态的改变。       &nbsp23 仲裁状态机   &nbsp仲裁状态机表示总线仲裁器的状态,定义如下:   &nbsptype arbiter_state is(IDLE,DEVl,DEV2,PARK);   &nbsp当主设备查询状态机输出使

16、能信号(search_master)时,导致仲裁状态机的状态改变。        &nbsp、        &nbsp状态转变过程如图5所示,状态机描述的VHDL代码略。             &nbsp仲裁器根据仲裁状态机当前状态控制仲裁授权信号(GNT)的给出。     

17、60;      &nbsp注:PARKMASTER是事先设置的停靠状态。       &nbsp24 仿真波形图   &nbsp由图6可以看出,测试文件模拟了一个设备申请和两个设备同时申请的情况,并给出了总线授权信号(GNT),验证了仲裁器逻辑的正确性。             &nbsp25 资源占用情况分析   &nbsp可编程逻辑器件使用Lattice公司的ispLSI2064E-135LTl00,在ispLever中综合本例程序,结果如表2。            

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论