- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于FPGA的PCI总线接口设计
———————————————————————————————— 作者:
———————————————————————————————— 日期:
基于FPGA的PCI总线接口设计
技术分类: 可编程器件? | 2021-03-05 21ic
在现代数据采集及处理系统中,ISA、EISA、MCA等扩展总线已无法适应高速数据传输的要求,而PCI局部总线以其优异性价比和适应性成为大多数系统的主流总线。
\o PCI总线 PCI总线特点
PCI总线宽度32位,可升级到64位;最高工作频率33MHz,支持猝发工作方式,使传输速度更高;低随机访问延迟(对从总线上的主控存放器到附属存放器的写访问延迟为60ns);处理器/内存子系统能力完全一致;隐含的中央仲裁器;多路复用体系构造减少了管脚数和PCI部件;给于ISA、EISA、MAC系统的PCI扩展板,减少了用户的开发本钱;对PCI扩展卡及元件能够自动配置,实现设备的即插即用;处理器独立,不依赖任何CPU,支持多种处理器及将来更高性能的处理器;支持64位地址;多主控制允许任何PCI主设备和从设备之间进展点对点访问;PCI提供数据和地址的奇偶校验功能,保证了数据的完整性和准确性。
PCI接口开发现状
目前开发PCI接口大体有两种方式,一是使用专用的PCI接口芯片,可以实现完整的PCI主控模块和目标模块接口功能,将复杂的PCI总线接口转换为相对简单的用户接口。用户只要设计转换后的总线接口即可,缩短了开发周期,缺点是用户可能只用到局部PCI接口功能,这样造成了一定的逻辑资源浪费,也缺乏灵活性,很可能增加板上的组件,导致产品本钱的增加和可靠性的降低。二是使用可编程器件,采用 \o FPGA FPGA的优点在于其灵活的可编程性,首先PCI接口可以依据插卡功能进展最优化,而不必实现所有的PCI功能,这样可以节约系统的逻辑资源。而且,用户可以将PCI插卡上的其他用户逻辑与PCI接口逻辑集成在一个芯片上,实现紧凑的系统设计。当系统升级时,只需对可编程器件重新进展逻辑设计,而无需更新PCB幅员。现在已经有越来越多的用户使用可编程器件如FPGA、 \o CPLD CPLD等进展PCI设备的开发。
本文所论述的PCI接口控制器是作为一个转换接口工作于PCI总线与用户设备之间,也可以认为其主要功能是起一个桥梁作用,完成用户设备与PCI总线间的信息传送。
PCI接口设计
在PCI板卡的设计中,核心设计有时序控制和配置空间两局部。时序控制保证了板卡能按正常的PCI时序工作,配置空间局部保证了板卡的即插即用功能。在进展FPGA设计时本设计使用的软件是Altera的MAX+PLUSII,开发芯片是EPF10K20RC240-3。
● PCI接口配置空间的实现
PCI总线定义了3种物理地址空间,分别是存储器地址空间、I/O地址空间和配置地址空间。
配置空间是PCI所特有的一种空间,其目的在于提供一套适当的配置措施,使之满足现行的和可预见的系统配置机构。配置空间是一长度为256字节并且有特定记录构造的地址空间,可以在系统自举时访问,也可在其他时间访问。该空间分为首部区和设备有关区两局部,设备在每个区中只须实现必要的和与之相关的存放器。配置空间的基地址存放器提供了一种为设备指定存储空间或I/O空间的机制。操作系统在启动的时候要判断系统中有多少存储器、系统中的I/O设备需要多少地址空间,然后根据得到的结果,自动配置系统的存储空间和I/O空间,实现设备无关管理。在本设计中,那些只读的配置存放器通过硬件连线到相应的值,因而不占用宏单元。通过配置存放器,配置软件可了解目标设备的存在、功能及配置要求。
(1)厂商ID:此16位的只读存放器定义了设备的生产厂商,可以使用MACH芯片最初的生产厂商-AMD公司的ID值1022。
(2)设备ID:该值由生产厂商分配以识别其产品,可为和0FFFFFFFFH中的任意值。
(3)命令存放器:此存放器控制了设备响应PCI访问的能力。位1、6、8在本设计中被实现。本设计要求实现对存储空间的访问,位1设置为1,那么设备响应PCI对存储器访问;位6控制了设备对奇偶校验错误的响应;当位8被设置为1时,设备能够驱动SERR线,0那么制止设备的SERR输出驱动器。在这里当系统复位后,位1、6、8被设置为0。
(4)状态存放器:此存放器记录了PCI相关事件的信息。在本系统中,位9、10、11、14、15被设计实现。位10∶9为设备选择(DEVSEL#)定时,00B为慢速,01B为中速,10B为快速,11B保存。本设计这两位被硬件连线为01B。当目标设备失败时,位11
文档评论(0)